双指针刷题(二)

所有算法文章链接(最底部)

http://t.csdnimg.cn/IbllR

目录

1.快乐数

分析题意

解题思路

代码实现

2.盛最多水的容器

分析题意

解题思路

代码实现


1.快乐数

力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台

分析题意

把一个正整数n的每一位都平方后相加,一直重复这个过程,在这个过程中如果出现1,说明这个数是快乐的,如果没出现就会陷入循环。

如过n = 2 就会陷入循环,2就不是快乐数。

解题思路

这道题无非就是两种情况,第一种是能出现1,第二种是没出现1陷入循环。

我们可以把这两种情况抽象成一种情况,两种情况都会进入循环,只不过第一种情况进入的都是1的循环中。

可以采用快慢指针的方法,快指针一次走2步,慢指针一次走一不。

不管哪种情况,快慢指针都会进入环中,而且一定会相遇,我们只需要判断相遇之后,位置是不是1就好了。

代码实现

cpp 复制代码
class Solution {
public:
    int getnum(int n){ //进行一步运算
        int ret = 0;
        while(n){
            int tmp = n%10;
            ret += tmp*tmp;
            n/=10;
        }
        return ret;
    }


    bool isHappy(int n) {
        int fast = getnum(n),slow = n;
        while(fast != slow){//快慢指针相遇就终止

            fast = getnum(getnum(fast));//块指针走两步
            slow = getnum(slow);//慢指针走一步

        }
        if(fast== 1){//判断快慢指针相遇后是否为1
            return true;
        }
        return false; 

    }
};

2.盛最多水的容器

力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台

分析题意

有一个存储板子的高度的数组,这些板子是可以切换的,问这些板子和x轴围成的容器,最大的容积是多少。

解题思路

这道题是一个非常明显的双指针算法,两个指针指向两块板子

维护一个容积的最大值

这两个指针,那个指针指向的板子高度低,哪个向中间移动,因为向中间移动,x轴会变短,容积会减小,向中间移动长板子的指针,容积要么减小要么不变,移动指向短板子的指针,容积要么不变要么变大。

代码实现

cpp 复制代码
class Solution {
public:
    int maxArea(vector<int>& height) {
        int l = 0, r = height.size()-1;
        int maxcap = 0;//最大容积
        while(l < r){//两个板子相遇就终止
            int len = r-l;
            int minheight = min(height[l],height[r]);//找到两个板子最小的高度
            maxcap = max(maxcap,len * minheight);//维护最大容积
            if(height[l] < height[r]) l++;//哪个板子短,哪个向中间移动
            else r--;
        
        }
        return maxcap;
    }
};
相关推荐
Jasmine_llq8 分钟前
《 火星人 》
算法·青少年编程·c#
闻缺陷则喜何志丹19 分钟前
【C++动态规划 图论】3243. 新增道路查询后的最短距离 I|1567
c++·算法·动态规划·力扣·图论·最短路·路径
Lenyiin37 分钟前
01.02、判定是否互为字符重排
算法·leetcode
鸽鸽程序猿1 小时前
【算法】【优选算法】宽搜(BFS)中队列的使用
算法·宽度优先·队列
Jackey_Song_Odd1 小时前
C语言 单向链表反转问题
c语言·数据结构·算法·链表
Watermelo6171 小时前
详解js柯里化原理及用法,探究柯里化在Redux Selector 的场景模拟、构建复杂的数据流管道、优化深度嵌套函数中的精妙应用
开发语言·前端·javascript·算法·数据挖掘·数据分析·ecmascript
乐之者v1 小时前
leetCode43.字符串相乘
java·数据结构·算法
A懿轩A2 小时前
C/C++ 数据结构与算法【数组】 数组详细解析【日常学习,考研必备】带图+详细代码
c语言·数据结构·c++·学习·考研·算法·数组
古希腊掌管学习的神2 小时前
[搜广推]王树森推荐系统——矩阵补充&最近邻查找
python·算法·机器学习·矩阵