算法每日一题 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 ;
    }
}

五、总结

  • 这题属于什么类型?
    这道题本质属于"数学 + 链表判环思想"的问题,可以看作是对数字进行不断变换后形成的序列问题。
相关推荐
JieE2121 天前
LeetCode 101. 对称二叉树|JS 递归 + 迭代双解法,彻底搞懂镜像判断
javascript·算法
JieE2122 天前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
Jack202 天前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树2 天前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
JieE2123 天前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE2123 天前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术3 天前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像
Darling噜啦啦3 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
用户497863050733 天前
(一)小红的数组操作
算法·编程语言