算法——双指针(day2)

目录

202.快乐数

题目解析:

算法解析:

代码:

11.盛最多水的容器

题目解析:

算法解析:

代码:


202.快乐数

力扣链接:202.快乐数

题目解析:

本文中最重要的一句话就是重复平方和过程直到数字变为1,也可能是无限循环始终不变1.

这里我们可以画出示例图来分析。

我们最终可以发现只有两种情况,要么内部循环都为1,要么内部循环不为1.而二者共同点就在于一定会循环~

算法解析:

这里我们还是可以使用双指针的解法------快慢指针~相信大家不会陌生,**快慢指针通过慢走一步快走两步的特点可以很快判断出来是否成环(即循环)。**而本题我们不需要验证是否循环,只需要在快慢指针相遇的时候(无限循环中)判断环中数字是否为1即可~

代码:

cpp 复制代码
class Solution {
public:
    //处理平方和
    int sumsum(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 = sumsum(n);
        //快慢指针相遇
        while (fast != slow)
        {
            slow = sumsum(slow);
            fast = sumsum(sumsum(fast));
        }
        return slow == 1;

    }
};

11.盛最多水的容器

11. 盛最多水的容器 - 力扣(LeetCode)

题目解析:

通过示例图可以我们看出基本计算为:选择的下标相减 X 两数间最小数

算法解析:

我们先划出一个小范围,然后尝试在该范围里面选出最大容量。我们优先选取两端数,这样可以保证长度是最长的,然后我们再尝试缩短范围(拿宽短的尝试比较),这样我们可以得出两种结果:

要么是 长度和宽度都减小了(2---4),要么是长度减小宽度不变(5--4).最终的容量都不如最开始v1(6--4)的大,因此我们可以直接排除4,因为在后续的比较中毫无意义。

当我们知道规律后就很简单了,列出双指针指向两端。记录每一次所指向的两个数对应的容量,然后两数谁小谁就先缩进一位继续比较,直到相遇。 最后我们再对比所有记录的容量选出最大的那个即可~

代码:

cpp 复制代码
class Solution {
public:
    int maxArea(vector<int>& height) {
        int n = height.size();
        int left = 0;
        int right = n-1;
        int sum = 0;
        int sum1 = 0;
        while(left<right)
        {
            sum1 = min(height[left],height[right])*(right-left);
            if(height[right]>=height[left])
            {
                left++;
            }
            else
            {
                right--;
            }
             sum = max(sum,sum1);
        }
        return sum;
    }
};
相关推荐
Coovally AI模型快速验证37 分钟前
MMYOLO:打破单一模式限制,多模态目标检测的革命性突破!
人工智能·算法·yolo·目标检测·机器学习·计算机视觉·目标跟踪
一只小bit40 分钟前
C++之初识模版
开发语言·c++
可为测控1 小时前
图像处理基础(4):高斯滤波器详解
人工智能·算法·计算机视觉
Milk夜雨2 小时前
头歌实训作业 算法设计与分析-贪心算法(第3关:活动安排问题)
算法·贪心算法
CodeClimb2 小时前
【华为OD-E卷 - 第k个排列 100分(python、java、c++、js、c)】
java·javascript·c++·python·华为od
BoBoo文睡不醒2 小时前
动态规划(DP)(细致讲解+例题分析)
算法·动态规划
apz_end3 小时前
埃氏算法C++实现: 快速输出质数( 素数 )
开发语言·c++·算法·埃氏算法
仟濹3 小时前
【贪心算法】洛谷P1106 - 删数问题
c语言·c++·算法·贪心算法
苦 涩3 小时前
考研408笔记之数据结构(七)——排序
数据结构
北顾南栀倾寒3 小时前
[Qt]系统相关-网络编程-TCP、UDP、HTTP协议
开发语言·网络·c++·qt·tcp/ip·http·udp