算法每日一题 Day03|快慢双指针解决快乐树问题

文章目录

快乐数(附链接)

https://leetcode.cn/problems/happy-number/description/

一、题目描述

二、思路

第一种情况,当n=19时,通过重复计算这个数最终变为1,形成一个全是1的环。

第二种情况,当n=2时,通过重复计算,发现最终也会形成一个环,一个没有1的环。

所以可以定义两个指针,快指针fast一次走两步,慢指针slow一次走一步,看它们相遇的时候的数是不是1,如果是1,则这个数就为快乐数,否则这个数就不是快乐数。

三、关键点

  • 能想到用快慢双指针来解决这道题

四、代码(Java / 你常用语言)

java 复制代码
class Solution {
    public int sqrtSum(int n) {
        int sum = 0;
        while (n != 0) {
            //计算每个位数上的平方和
            int i = n % 10;
            sum += i * i;
            n = n / 10;
        }
        return sum;
    }

    public boolean isHappy(int n) {
        //让fast指针先走一步,这样才能进入后面的循环中
        int fast = sqrtSum(n);
        int slow = n;
        while (slow != fast) {
            //slow走一步,fast走两步
            slow = sqrtSum(slow);
            fast = sqrtSum(sqrtSum(fast));
        }
       
        return slow ==1 ;
    }
}

五、总结

  • 这题属于什么类型?
    这道题本质属于"数学 + 链表判环思想"的问题,可以看作是对数字进行不断变换后形成的序列问题。
相关推荐
ZPC82102 小时前
MoveGroup 规划轨迹 → 直接交给 MoveIt2 Servo 执行
人工智能·算法·计算机视觉·机器人
️是782 小时前
信息奥赛一本通—编程启蒙(3373:练64.2 图像旋转翻转变换)
数据结构·c++·算法
木子墨5162 小时前
LeetCode 热题 100 精讲 | 计算几何篇:点积叉积 · 线段相交 · 凸包 · 多边形面积
c++·算法·leetcode·职场和发展·动态规划
源码之家2 小时前
计算机毕业设计:Python棉花产业数据可视化与预测系统 Django框架 ARIMA算法 数据分析 可视化 爬虫 大数据 大模型(建议收藏)✅
人工智能·python·算法·信息可视化·数据挖掘·django·课程设计
py有趣2 小时前
力扣热门100题之最小路径和
算法·leetcode
qeen873 小时前
【算法笔记】前缀和经典题目解析
c语言·c++·笔记·学习·算法
Je1lyfish3 小时前
Haskell 初探
开发语言·笔记·算法·rust·lisp·抽象代数
im_AMBER3 小时前
Leetcode 159 无重复字符的最长子串 | 长度最小的子数组
javascript·数据结构·学习·算法·leetcode
浮芷.3 小时前
微观搜打撤:基于鸿蒙flutter的内存快照算法的局内外状态隔离与高阶背包系统设计
算法·flutter·华为·开源·harmonyos·鸿蒙