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;
    }
};
相关推荐
8Qi81 小时前
LeetCode 208:实现 Trie(前缀树)—— Java 题解 ✅
java·算法·leetcode·二叉树·tire树
吴可可1231 小时前
CAD2004二次开发C#可行性解析
算法
字节高级特工1 小时前
C++11(二) 革新:引用折叠与lambda表达式
java·开发语言·c++·算法
碎碎念_4921 小时前
”二分“高频题型总结:最小最大值、最大最小值、满足条件最小 / 最大
算法·二分
罗超驿1 小时前
14.LeetCode 438 题解:滑动窗口+哈希表找所有字母异位词
java·算法·leetcode
小欣加油2 小时前
leetcode239 滑动窗口最大值
数据结构·c++·算法·leetcode·哈希算法
luoganttcc2 小时前
FP16 和 BF16 的数学表达
算法
玖釉-2 小时前
Vulkan 示例解析:pipelines.cpp 如何在一个 Render Pass 中切换多条 Graphics Pipeline
c++·windows·算法·图形渲染
ji198594432 小时前
局部线性嵌入(LLE)算法 MATLAB 实现
算法·机器学习·matlab