1
1.3 题目示例
1.4 算法思路
- 首先在反复计算平方和过程中,数字会变化但是不会一直增大,这是为什么?
当一个数足够大的时候,比如999,它的平方和会小于原数,所以最终会进入一个人循环。比如
4 → 16 → 37 → 58 → 89 → 145 → 42 → 20 → 4这是一个不属于快乐数的循环。
- 所以我们在判断在平方和序列中,判断是否是快乐数的问题需要转变成判断我们最终是到达 1,还是进入某个不含 1 的循环。
- 此时我们就可以运用双指针中的
快慢指针来解决这个问题,因为如果循环他们最终一定会相遇,然后判断他们相遇时候的数字是不是1就可以判断出是不是快乐数了,那么我们怎么实现这个快慢指针呢? - 我们可以让慢指针(初始为这个数)每次走一步,然后计算一次它的平方和;快指针(初始为这个数的平方和)一次走两步,计算两次它的平方和;并且每次走完判断他们的值相不相等。
就比如2,最后在42这个数的时候相遇,说明并不是快乐数。
在这里插入图片描述
1.5 核心代码实现
代码语言:javascript
AI代码解释
//快乐数和盛水最多的容器 #include<iostream> using namespace std; class Solution { public: int bitSum(int n) //计算给定的数字的平方和用来初始化快指针 和 后续操作的平方和计算 { int sum = 0; while (n)//利用循环取出单独每个位置的数字然后求平方进行相加求出平方和 { int a = n % 10; sum += a * a; n /= 10; } return sum; } bool isHappy(int n) { int slow = n;//慢指针初始化这个数 int fast = bitSum(n);//快指针初始化为这个数的平方和 while (slow != fast)//循环停止条件:他们相等 { slow = bitSum(slow);//慢指针走一步 fast = bitSum(bitSum(fast));//快指针走两步 } return slow == 1;//相等的时候==1就返回正确否则错误 } };1.6 示例测试(总代码)
代码语言:javascript
AI代码解释
//快乐数和盛水最多的容器 #include<iostream> using namespace std; class Solution { public: int bitSum(int n) //计算给定的数字的平方和用来初始化快指针 和 后续操作的平方和计算 { int sum = 0; while (n)//利用循环取出单独每个位置的数字然后求平方进行相加求出平方和 { int a = n % 10; sum += a * a; n /= 10; } return sum; } bool isHappy(int n) { int slow = n;//慢指针初始化这个数 int fast = bitSum(n);//快指针初始化为这个数的平方和 while (slow != fast)//循环停止条件:他们相等 { slow = bitSum(slow);//慢指针走一步 fast = bitSum(bitSum(fast));//快指针走两步 } return slow == 1;//相等的时候==1就返回正确否则错误 } }; int main() { int test1 = 19; int test2 = 2; int test3 = 1; cout << test1 << " 是快乐数吗? "; if (Solution().isHappy(test1)) { cout << "是" << endl; } else { cout << "否" << endl; } cout << test2 << " 是快乐数吗? "; if (Solution().isHappy(test2)) { cout << "是" << endl; } else { cout << "否" << endl; } cout << test3 << " 是快乐数吗? "; if (Solution().isHappy(test3)) { cout << "是" << endl; } else { cout << "否" << endl; } return 0; }在这里插入图片描述
2. 盛水最多的容器
2.1 题目链接
链接直达请点击<----------
2.2 题目描述
在这里插入图片描述
2.3 题目示例
在这里插入图片描述
2.4 算法思路
- 首先我们得明白它的容器容积是如何计算的?通过代码示例我们可以发现是用数据中的两个元素中较小的那个乘以他们的下标之差就是他们的容积,所以我们要做的就是通过这个求出其最大值。那么如何计算这个最大值?
- 我们可以设置一个双指针,采用
对撞式指针其中一个指向开头,第二个指向末尾,计算出容积;然后比较两个指针大小并移动较小长度的指针,为什么移动较小的而不移动较长的?
在这里插入图片描述
- 通过上图发现,我们的容积是受限于长度小的,移动指针的话他们的下标之差会越来越小,单调递减的;如果我们移动长的其长度最长会保持不变,否则反而可能减小,这样的结果是一直递减的;反之我们移动短的,虽然下标之差在减小,但是我们的长度可能更高,所以选择移动短的。
- 最后在把每次移动后计算的容积进行比较,不断更新那个大的值,最后返回。
2.5 核心代码实现
代码语言:javascript
AI代码解释
class Solution { public: int maxArea(vector<int>& height) { int left = 0; int right = height.size() - 1; int ret = 0; while (left < right) { int v = min(height[left], height[right]) * (right - left); ret = max(v, ret); if (height[left] < height[right]) left++; else right--; } return ret; } };2.6 示例测试(总代码)
代码语言:javascript
AI代码解释
#include<iostream> using namespace std; #include<vector> class Solution { public: int maxArea(vector<int>& height) { int left = 0; int right = height.size() - 1; int ret = 0; while (left < right) { int v = min(height[left], height[right]) * (right - left); ret = max(v, ret); if (height[left] < height[right]) left++; else right--; } return ret; } }; int main() { Solution sol; vector<int> height1 = { 1,8,6,2,5,4,8,3,7 }; cout << "测试1: " << sol.maxArea(height1) << endl; vector<int> height2 = { 1,1 }; cout << "测试2: " << sol.maxArea(height2) << endl; vector<int> height3 = { 4,3,2,1,4 }; cout << "测试3: " << sol.maxArea(height3) << endl; return 0; }在这里插入图片描述
总结
在本篇文章中,我们通过「快乐数」与「盛水最多的容器」两个经典题目,深入理解了双指针(Two Pointers)的核心思想与进阶应用。
- 快乐数:运用快慢指针检测循环,将数学问题转化为链表环检测问题,巧妙判断数字是否会陷入无限循环
- 盛水最多的容器:采用对撞指针策略,通过移动较短板来寻找最大容量,展现了贪心思想的精妙运用
这两种双指针模式(快慢指针、对撞指针)是算法竞赛和面试中的常客,掌握它们能帮助我们高效解决各类数组和链表问题。
m.nxhfl.pro/post/11757.html
m.nxhfl.pro/post/79719.html
m.nxhfl.pro/post/24682.html
m.nxhfl.pro/post/68046.html
m.nxhfl.pro/post/44202.html
m.nxhfl.pro/post/33995.html
m.nxhfl.pro/post/84266.html
m.nxhfl.pro/post/35555.html
m.nxhfl.pro/post/46260.html
m.nxhfl.pro/post/57197.html
m.nxhfl.pro/post/35133.html
m.nxhfl.pro/post/62442.html
m.nxhfl.pro/post/57593.html
m.nxhfl.pro/post/51913.html
m.nxhfl.pro/post/75575.html
m.nxhfl.pro/post/75777.html
m.nxhfl.pro/post/93391.html
m.nxhfl.pro/post/35575.html
m.nxhfl.pro/post/57393.html
m.nxhfl.pro/post/91717.html
m.nxhfl.pro/post/37917.html
m.nxhfl.pro/post/39713.html
m.nxhfl.pro/post/19999.html
m.nxhfl.pro/post/13943.html
m.nxhfl.pro/post/17797.html
m.nxhfl.pro/post/57117.html
m.nxhfl.pro/post/53777.html
m.nxhfl.pro/post/19555.html
m.nxhfl.pro/post/97931.html
m.nxhfl.pro/post/17917.html
m.nxhfl.pro/post/59995.html
m.nxhfl.pro/post/26004.html
m.nxhfl.pro/post/33979.html
m.nxhfl.pro/post/79795.html
m.nxhfl.pro/post/19337.html
m.nxhfl.pro/post/77371.html
m.nxhfl.pro/post/13599.html
m.nxhfl.pro/post/99553.html
m.nxhfl.pro/post/99511.html
m.nxhfl.pro/post/80848.html
m.nxhfl.pro/post/19733.html
m.nxhfl.pro/post/19711.html
m.nxhfl.pro/post/33771.html
m.nxhfl.pro/post/44668.html
m.nxhfl.pro/post/15399.html
m.nxhfl.pro/post/13491.html
m.nxhfl.pro/post/93571.html
m.nxhfl.pro/post/53177.html
m.nxhfl.pro/post/11317.html
m.nxhfl.pro/post/46046.html
m.nxhfl.pro/post/68620.html
m.nxhfl.pro/post/97313.html
m.nxhfl.pro/post/19777.html
m.nxhfl.pro/post/68466.html
m.nxhfl.pro/post/37777.html
m.nxhfl.pro/post/02280.html
m.nxhfl.pro/post/99339.html
m.nxhfl.pro/post/97377.html
m.nxhfl.pro/post/57337.html
m.nxhfl.pro/post/73913.html
m.nxhfl.pro/post/73593.html
m.nxhfl.pro/post/15335.html
m.nxhfl.pro/post/95377.html
m.nxhfl.pro/post/13795.html
m.nxhfl.pro/post/91979.html
m.nxhfl.pro/post/75913.html
m.nxhfl.pro/post/33975.html
m.nxhfl.pro/post/19779.html
m.nxhfl.pro/post/31513.html
m.nxhfl.pro/post/73931.html
m.nxhfl.pro/post/17757.html
m.nxhfl.pro/post/91519.html
m.nxhfl.pro/post/97133.html
m.nxhfl.pro/post/68808.html
m.nxhfl.pro/post/68448.html
m.nxhfl.pro/post/79953.html
m.nxhfl.pro/post/97191.html
m.nxhfl.pro/post/51199.html
m.nxhfl.pro/post/44002.html
m.nxhfl.pro/post/17513.html
m.nxhfl.pro/post/15359.html
m.nxhfl.pro/post/48444.html
m.nxhfl.pro/post/55113.html
m.nxhfl.pro/post/15319.html
m.nxhfl.pro/post/37173.html
m.nxhfl.pro/post/86240.html
m.nxhfl.pro/post/77775.html
m.nxhfl.pro/post/39511.html
m.nxhfl.pro/post/97991.html
m.nxhfl.pro/post/68886.html
m.nxhfl.pro/post/53933.html
m.nxhfl.pro/post/53191.html
m.nxhfl.pro/post/51333.html
m.nxhfl.pro/post/03059.html
m.nxhfl.pro/post/53751.html
m.nxhfl.pro/post/53711.html
m.nxhfl.pro/post/39933.html
m.nxhfl.pro/post/22428.html
m.nxhfl.pro/post/71935.html
m.nxhfl.pro/post/31731.html
m.nxhfl.pro/post/53715.html
m.nxhfl.pro/post/04680.html
m.nxhfl.pro/post/84680.html
m.nxhfl.pro/post/95751.html
m.nxhfl.pro/post/55575.html
m.nxhfl.pro/post/60686.html
m.nxhfl.pro/post/71311.html
m.nxhfl.pro/post/59115.html
m.nxhfl.pro/post/77517.html
m.nxhfl.pro/post/72178.html
m.nxhfl.pro/post/79591.html
m.nxhfl.pro/post/53353.html
m.nxhfl.pro/post/95715.html
m.nxhfl.pro/post/95315.html
m.nxhfl.pro/post/24466.html
m.nxhfl.pro/post/13553.html
m.nxhfl.pro/post/91917.html
m.nxhfl.pro/post/20820.html
m.nxhfl.pro/post/08260.html
m.nxhfl.pro/post/13535.html
m.nxhfl.pro/post/91359.html
m.nxhfl.pro/post/08466.html
m.nxhfl.pro/post/55199.html
m.nxhfl.pro/post/75957.html
m.nxhfl.pro/post/33511.html
m.nxhfl.pro/post/71837.html
m.nxhfl.pro/post/99753.html
m.nxhfl.pro/post/39173.html
m.nxhfl.pro/post/55759.html
m.nxhfl.pro/post/31135.html
m.nxhfl.pro/post/91793.html
m.nxhfl.pro/post/35155.html
m.nxhfl.pro/post/75557.html
m.nxhfl.pro/post/77539.html
m.nxhfl.pro/post/15131.html
m.nxhfl.pro/post/59351.html
m.nxhfl.pro/post/86660.html
m.nxhfl.pro/post/20080.html
m.nxhfl.pro/post/37711.html
m.nxhfl.pro/post/93935.html
m.nxhfl.pro/post/31933.html
m.nxhfl.pro/post/19939.html
m.nxhfl.pro/post/48020.html
m.nxhfl.pro/post/79739.html
m.nxhfl.pro/post/77977.html
m.nxhfl.pro/post/55715.html
m.nxhfl.pro/post/51171.html
m.nxhfl.pro/post/15959.html
m.nxhfl.pro/post/99539.html
m.nxhfl.pro/post/84686.html
m.nxhfl.pro/post/13717.html
m.nxhfl.pro/post/42020.html
m.nxhfl.pro/post/20004.html
m.nxhfl.pro/post/75159.html
m.nxhfl.pro/post/57199.html
m.nxhfl.pro/post/59975.html
m.nxhfl.pro/post/00288.html
m.nxhfl.pro/post/95793.html
m.nxhfl.pro/post/35779.html
m.nxhfl.pro/post/42820.html
m.nxhfl.pro/post/57195.html
m.nxhfl.pro/post/79597.html
m.nxhfl.pro/post/31357.html
m.nxhfl.pro/post/59399.html
m.nxhfl.pro/post/55719.html
m.nxhfl.pro/post/93313.html
m.nxhfl.pro/post/88280.html
m.nxhfl.pro/post/99155.html
m.nxhfl.pro/post/48408.html
m.nxhfl.pro/post/19359.html
m.nxhfl.pro/post/15595.html
m.nxhfl.pro/post/66246.html
m.nxhfl.pro/post/11955.html
m.nxhfl.pro/post/55917.html
m.nxhfl.pro/post/91559.html
m.nxhfl.pro/post/26280.html
m.nxhfl.pro/post/39571.html
m.nxhfl.pro/post/79175.html
m.nxhfl.pro/post/17157.html
m.nxhfl.pro/post/97975.html
m.nxhfl.pro/post/57951.html
m.nxhfl.pro/post/73173.html
m.nxhfl.pro/post/59111.html
m.nxhfl.pro/post/75513.html
m.nxhfl.pro/post/37577.html
m.nxhfl.pro/post/31537.html
m.nxhfl.pro/post/84286.html
m.nxhfl.pro/post/39931.html
m.nxhfl.pro/post/93373.html
m.nxhfl.pro/post/60664.html
m.nxhfl.pro/post/20222.html
m.nxhfl.pro/post/75531.html
m.nxhfl.pro/post/55979.html
m.nxhfl.pro/post/57793.html
m.nxhfl.pro/post/39913.html
m.nxhfl.pro/post/91113.html
m.nxhfl.pro/post/19931.html
m.nxhfl.pro/post/19973.html
m.nxhfl.pro/post/31579.html
m.nxhfl.pro/post/86226.html
m.nxhfl.pro/post/77959.html
m.nxhfl.pro/post/82068.html
m.nxhfl.pro/post/55557.html
m.nxhfl.pro/post/71795.html
m.nxhfl.pro/post/75771.html
m.nxhfl.pro/post/35591.html
m.nxhfl.pro/post/95755.html
m.nxhfl.pro/post/73139.html
m.nxhfl.pro/post/19731.html
m.nxhfl.pro/post/57157.html
m.nxhfl.pro/post/84048.html
m.nxhfl.pro/post/19519.html
m.nxhfl.pro/post/79599.html
m.nxhfl.pro/post/79771.html
m.nxhfl.pro/post/73915.html
m.nxhfl.pro/post/11359.html
m.nxhfl.pro/post/42680.html
m.nxhfl.pro/post/93377.html
m.nxhfl.pro/post/64044.html
m.nxhfl.pro/post/95579.html
m.nxhfl.pro/post/31193.html
m.nxhfl.pro/post/97353.html
m.nxhfl.pro/post/15915.html
m.nxhfl.pro/post/93537.html
m.nxhfl.pro/post/55173.html
m.nxhfl.pro/post/13591.html
m.nxhfl.pro/post/31531.html
m.nxhfl.pro/post/60020.html
m.nxhfl.pro/post/28246.html
m.nxhfl.pro/post/13159.html
m.nxhfl.pro/post/17791.html
m.nxhfl.pro/post/37515.html
m.nxhfl.pro/post/33333.html
m.nxhfl.pro/post/31711.html
m.nxhfl.pro/post/77397.html
m.nxhfl.pro/post/71595.html
m.nxhfl.pro/post/91571.html
m.nxhfl.pro/post/13517.html
m.nxhfl.pro/post/15159.html
m.nxhfl.pro/post/42082.html
m.nxhfl.pro/post/13797.html
m.nxhfl.pro/post/39515.html
m.nxhfl.pro/post/66820.html
m.nxhfl.pro/post/28080.html
m.nxhfl.pro/post/53791.html
m.nxhfl.pro/post/00204.html
m.nxhfl.pro/post/22604.html
m.nxhfl.pro/post/13735.html
m.nxhfl.pro/post/86842.html
m.nxhfl.pro/post/53339.html
m.nxhfl.pro/post/77979.html
m.nxhfl.pro/post/77173.html
m.nxhfl.pro/post/53731.html
m.nxhfl.pro/post/97179.html
m.nxhfl.pro/post/75757.html
m.nxhfl.pro/post/13375.html
m.nxhfl.pro/post/59193.html
m.nxhfl.pro/post/19355.html
m.nxhfl.pro/post/17135.html
m.nxhfl.pro/post/79317.html
m.nxhfl.pro/post/95775.html
m.nxhfl.pro/post/79915.html
m.nxhfl.pro/post/26406.html
m.nxhfl.pro/post/35735.html
m.nxhfl.pro/post/79731.html
m.nxhfl.pro/post/57771.html
m.nxhfl.pro/post/22200.html
m.nxhfl.pro/post/75313.html
m.nxhfl.pro/post/99513.html
m.nxhfl.pro/post/88666.html
m.nxhfl.pro/post/71533.html
m.nxhfl.pro/post/33153.html
m.nxhfl.pro/post/88208.html
m.nxhfl.pro/post/75193.html
m.nxhfl.pro/post/99535.html
m.nxhfl.pro/post/39991.html
m.nxhfl.pro/post/91111.html
m.nxhfl.pro/post/93753.html
m.nxhfl.pro/post/73535.html
m.nxhfl.pro/post/62428.html
m.nxhfl.pro/post/95791.html
m.nxhfl.pro/post/99157.html
m.nxhfl.pro/post/17955.html
m.nxhfl.pro/post/93177.html
m.nxhfl.pro/post/95155.html
m.nxhfl.pro/post/11795.html
m.nxhfl.pro/post/73379.html
m.nxhfl.pro/post/53115.html
m.nxhfl.pro/post/60046.html
m.nxhfl.pro/post/55755.html
m.nxhfl.pro/post/86608.html
m.nxhfl.pro/post/35397.html
m.nxhfl.pro/post/53155.html
m.nxhfl.pro/post/46008.html
m.nxhfl.pro/post/51539.html
m.nxhfl.pro/post/80080.html
m.nxhfl.pro/post/55751.html
m.nxhfl.pro/post/71153.html
m.nxhfl.pro/post/15973.html
m.nxhfl.pro/post/11573.html
m.nxhfl.pro/post/08428.html
m.nxhfl.pro/post/39115.html
m.nxhfl.pro/post/15919.html
m.nxhfl.pro/post/57115.html
m.nxhfl.pro/post/71539.html
m.nxhfl.pro/post/59997.html
m.nxhfl.pro/post/40844.html
m.nxhfl.pro/post/28226.html
m.nxhfl.pro/post/99199.html
m.nxhfl.pro/post/48739.html
m.nxhfl.pro/post/11337.html
m.nxhfl.pro/post/88022.html
m.nxhfl.pro/post/91935.html
m.nxhfl.pro/post/31937.html
m.nxhfl.pro/post/82460.html
m.nxhfl.pro/post/79351.html
m.nxhfl.pro/post/71111.html
m.nxhfl.pro/post/99577.html
m.nxhfl.pro/post/59939.html
m.nxhfl.pro/post/77571.html
m.nxhfl.pro/post/66204.html
m.nxhfl.pro/post/71513.html
m.nxhfl.pro/post/17315.html
m.nxhfl.pro/post/71577.html
m.nxhfl.pro/post/79379.html
m.nxhfl.pro/post/93337.html
m.nxhfl.pro/post/17953.html
m.nxhfl.pro/post/19579.html
m.nxhfl.pro/post/57171.html
m.nxhfl.pro/post/44082.html
m.nxhfl.pro/post/82080.html
m.nxhfl.pro/post/93915.html
m.nxhfl.pro/post/35737.html
m.nxhfl.pro/post/35115.html
m.nxhfl.pro/post/66602.html
m.nxhfl.pro/post/11335.html
m.nxhfl.pro/post/48240.html
m.nxhfl.pro/post/80608.html
m.nxhfl.pro/post/39159.html
m.nxhfl.pro/post/13519.html
m.nxhfl.pro/post/93591.html
m.nxhfl.pro/post/93319.html
m.nxhfl.pro/post/33133.html
m.nxhfl.pro/post/31511.html
m.nxhfl.pro/post/15559.html
m.nxhfl.pro/post/79531.html
m.nxhfl.pro/post/82682.html
m.nxhfl.pro/post/11733.html
m.nxhfl.pro/post/99151.html
m.nxhfl.pro/post/26668.html
m.nxhfl.pro/post/20622.html
m.nxhfl.pro/post/13937.html
m.nxhfl.pro/post/91577.html
m.nxhfl.pro/post/37111.html
m.nxhfl.pro/post/75117.html
m.nxhfl.pro/post/79171.html
m.nxhfl.pro/post/95151.html
m.nxhfl.pro/post/40862.html
m.nxhfl.pro/post/37937.html
m.nxhfl.pro/post/00820.html
m.nxhfl.pro/post/59559.html
m.nxhfl.pro/post/15351.html
m.nxhfl.pro/post/62882.html
m.nxhfl.pro/post/53999.html
m.nxhfl.pro/post/77117.html
m.nxhfl.pro/post/19591.html
m.nxhfl.pro/post/73553.html
m.nxhfl.pro/post/46826.html
m.nxhfl.pro/post/53157.html
m.nxhfl.pro/post/73351.html
m.nxhfl.pro/post/33351.html
m.nxhfl.pro/post/06408.html
m.nxhfl.pro/post/97997.html
m.nxhfl.pro/post/15535.html
m.nxhfl.pro/post/53931.html
m.nxhfl.pro/post/73911.html
m.nxhfl.pro/post/00404.html
m.nxhfl.pro/post/48220.html
m.nxhfl.pro/post/00880.html
m.nxhfl.pro/post/77333.html
m.nxhfl.pro/post/31155.html
m.nxhfl.pro/post/17957.html
m.nxhfl.pro/post/22424.html
m.nxhfl.pro/post/00408.html
m.nxhfl.pro/post/15395.html
m.nxhfl.pro/post/39759.html
m.nxhfl.pro/post/35775.html
m.nxhfl.pro/post/59391.html
m.nxhfl.pro/post/73155.html
m.nxhfl.pro/post/31951.html
m.nxhfl.pro/post/39939.html
m.nxhfl.pro/post/42208.html