【C++算法】4.双指针_快乐数

文章目录


题目链接:

202.快乐数


题目描述:


解法

根据题目来看,可能是无限循环,也可能是快乐数。因为就相当于下图:

无限循环可以看成一个圈,快乐数得到的1也可以看成一个圈。因为对1求快乐数得到的也是1,相当于在1里循环。所以就相当于下图。

快慢双指针

  1. 定义快慢指针(用数来充当指针)

    例如:n = 19

    slow = 12+92=82

    fast = 82+22=68

  2. 慢指针每次向后移动一步

    快指针每次向后移动两步

  3. 因为快慢指针速度不一样,所以如果存在环的话,两个指针一定会在环里的某处相遇的(前面数据结构博客里面环形链表讲过这个)博客链接🔗


C++ 算法代码:

cpp 复制代码
class Solution 
{
public:
    int bitSum(int n) // 返回 n 这个数每一位上的平方和
    {
        int sum = 0;
        while(n)//把最后一位拿出来,然后除以10,循环直到为0为止。
        {
            int t = n % 10;
            sum += t * t;
            n /= 10;
        }
        return sum;//sum就是最终结果
	}
    
    bool isHappy(int n)
    {
        //用数来充当指针
        int slow = n, fast = bitSum(n);//这里fast是n求过一次平方和的值,目的是能够顺利进入下面的循环。因为如果fast和slow都是n的话,就无法循环了
        while(slow != fast)//slow!=fast就一直循环
        {
            slow = bitSum(slow);//慢指针走1步
            fast = bitSum(bitSum(fast));//快指针走2步
        }
        return slow == 1;//slow=1就是快乐数,不是1就不是快乐数
    }
};

图解:

输入19

  1. slow=19,fast=82
  2. slow=82,fast=100
  3. slow=68,fast=1
  4. slow=100,fast=1
  5. slow==fast
  6. return slow==1
相关推荐
学高数就犯困10 分钟前
性能优化:LRU缓存(清晰易懂带图解)
算法
xlp666hub2 小时前
Leetcode第七题:用C++解决接雨水问题
c++·leetcode
CoovallyAIHub3 小时前
CVPR 2026 | MixerCSeg:仅2.05 GFLOPs刷新四大裂缝分割基准!解耦Mamba隐式注意力,CNN+Transformer+Mamba三
深度学习·算法·计算机视觉
CoovallyAIHub3 小时前
YOLO26-Pose 深度解读:端到端架构重新设计,姿态估计凭什么跨代领先?
深度学习·算法·计算机视觉
CoovallyAIHub4 小时前
化工厂气体泄漏怎么用AI检测?30张图3D重建气体泄漏场景——美国国家实验室NeRF新研究
深度学习·算法·计算机视觉
肆忆_4 小时前
实战复盘:手写 C++ 虚拟机的高性能并行 GC (Thread Pool + Work Stealing)
c++
肆忆_4 小时前
虚函数进阶答疑:把上一篇博客评论区里最容易卡住的问题,一次追到底
c++
颜酱15 小时前
图的数据结构:从「多叉树」到存储与遍历
javascript·后端·算法
saltymilk20 小时前
使用 C++ 模拟 ShaderLanguage 的 swizzle
c++·模板元编程
zone773920 小时前
006:RAG 入门-面试官问你,RAG 为什么要切块?
后端·算法·面试