leetcode202.快乐数

202. 快乐数 - 力扣(LeetCode)

解题思路

方法一:

要么到 1,要么无限循环(重复出现某个数)。

所以我们只需要:

每次计算平方和 → 看是否重复 → 重复 = 不是快乐数

c++代码:

cpp 复制代码
class Solution {
public:
    int getnum(int n) {//计算平方和
        int sum = 0;
        while (n > 0) {
            int num = n % 10;//去最后一个数字
            sum += num * num;//平方累加
            n /= 10;//去掉最后一位
        }
        return sum;
    }
    bool isHappy(int n) {
        unordered_set<int> s;// 记录出现过的数字
        while (true) {
            int sum = getnum(n);
            if (sum == 1)//如果为1,是快乐数
                return true;
            if (s.count(sum))//如果出现重复的就不是快乐数
                return false;
            s.insert(sum);
            n = sum;
        }
    }
};

方法二:

不是快乐数 → 一定会进入循环

快慢指针:快指针走两步,慢指针走一步

如果相遇 == 有环(不是快乐数)

如果快指针走到 1 == 快乐数

我们通过计算发现这是循环的,而且这个可以抽象成链表是否有环来解题

这就可以用快慢指针的方法解题

慢指针走一步,快指针走两步

c++代码:

cpp 复制代码
class Solution {
public:
    int getnum(int n) {
        int sum = 0;
        while (n > 0) {
            int num = n % 10;
            sum += num * num;
            n /= 10;
        }
        return sum;
    }
    bool isHappy(int n) {
        int slow = n;// 慢指针:初始在起点,每次走1次平方和
        int fast = getnum(n);// 快指针:先走一步,每次走2次平方和
        while (fast != 1 && slow != fast) {
            slow = getnum(slow);         // 走一步
            fast = getnum(getnum(fast)); // 走两步
        }
        return fast == 1;
    }
};
相关推荐
To_OC10 小时前
手写快排次次翻车?别死背快排模板了,这才是面试官想听的底层逻辑
javascript·算法·排序算法
饼干哥哥11 小时前
Reddit VOC调研太慢?搭一个AI专家团队半小时洞察任何品类|以猫用饮水机为例
人工智能·算法·ai编程
地平线开发者12 小时前
Transformer模型部署之性能优化指南
算法
地平线开发者13 小时前
人在途中:从“编译失败”到“模型可落地”——CUDA 自定义算子
算法·自动驾驶
半个落月15 小时前
从递归到快速排序:用 JavaScript 把分治思想讲明白
javascript·算法·面试
小月土星16 小时前
JavaScript 快速排序:从 pivot、双指针到分治思想
javascript·算法·面试
小月土星17 小时前
JavaScript 递归入门:从 1 到 n 求和,再到数组扁平化
javascript·算法·面试
To_OC1 天前
LC 1 两数之和:面试第一道必考题,暴力解法直接被面试官 pass
javascript·算法·leetcode
鱼鱼不愚与2 天前
《原来如此 | 第01期:为什么导航软件能预测红绿灯倒计时?》
算法