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

五、总结

  • 这题属于什么类型?
    这道题本质属于"数学 + 链表判环思想"的问题,可以看作是对数字进行不断变换后形成的序列问题。
相关推荐
阿文的代码库2 小时前
递归与迭代的形式实现
算法·动态规划
春日见2 小时前
自动驾驶数据驱动规控进化之路
运维·服务器·人工智能·深度学习·算法·机器学习·自动驾驶
普贤莲花2 小时前
【【2026年第22周---写于20260531】---好好工作,好好生活】
程序人生·算法·leetcode·生活
Bingorl2 小时前
机器学习之聚类算法
算法·机器学习·聚类
小欣加油2 小时前
leetcode2126 摧毁小行星
数据结构·c++·算法·leetcode·职场和发展
菜菜的顾清寒2 小时前
力扣HOT100(45) 二叉树的直径
算法·leetcode·职场和发展
_Oracle2 小时前
机器学习——常见算法
人工智能·算法·机器学习
x_xbx2 小时前
LeetCode:17. 电话号码的字母组合
算法·leetcode·职场和发展
山楂树の2 小时前
广度优先搜索 (BFS)
算法·广度优先·宽度优先
say_fall2 小时前
深入理解Linux内核进程调度:从基础概念到O(1)调度算法
linux·运维·服务器·算法·计算机组成