稀碎从零算法笔记Day19-LeetCode:快乐数

题型:哈希表、数组

链接:202. 快乐数 - 力扣(LeetCode)

来源:LeetCode

题目描述

编写一个算法来判断一个数 n 是不是快乐数。

「快乐数」 定义为:

  • 对于一个正整数,每一次将该数替换为它每个位置上的数字的平方和。
  • 然后重复这个过程直到这个数变为 1,也可能是 无限循环 但始终变不到 1。
  • 如果这个过程 结果为 1,那么这个数就是快乐数。

如果 n快乐数 就返回 true ;不是,则返回 false

题目样例

示例 1:

复制代码
输入:n = 19
输出:true
解释:
12 + 92 = 82
82 + 22 = 68
62 + 82 = 100
12 + 02 + 02 = 1

示例 2:

复制代码
输入:n = 2
输出:false

提示:

  • 1 <= n <= 231 - 1

题目思路

题目可以分解为 ①求各位的平方和 ②判断平方和是否为1,这种感觉可以递归来不断的求平方和,求完后判断下等于 1

求平方和:创一个sum来接收每个数位的平方,单个数位可以用【取余10】和【除以10】来实现取数。当然不知道循环多少次,直接while(n != 0)就行

判1:sum主要有三种情况 ①等于1 ②不等于1 ③趋于∞

感觉难点在于说服自己【它趋于不了∞】这点

抛开严谨的数学证明,看了题解后有所收获:可以自己算一下"9" "99" "999" "9999" "99999"...这些数的各位平方和 ,虽然位数很多,但是最终都变成了【n*81】------其中n是位数。经过一次计算后原本很夸张的数字变得小了许多,且后面的数字都不如【每一位都是9】这个设定下的平方和大。这样的话会好理解许多

最终sum只有两种情况,问题就演变成了【看sum会不会"循环"】------即是之前出现过一次的值又出现了。这种【判断重复出现】的类型,很自然想到用hash来实现。基于链表的数据结构无法用【数组】来说明"这个指针又回到了这里"这种情况,所以可以用unordered_set<int>来存储链表结点(与unordered_map相同,int是key)。

C++代码

cpp 复制代码
class Solution {
public:
    //获得各位平方和的函数 
    int getnum(int n)
    {
        int sum=0;
        while(n != 0)
        {
            sum += (n%10) * (n%10);
            n/=10;
        }
        return sum;
    }
    bool isHappy(int n) {
        if(n==1 || n==0)
            return n;
        unordered_set<int> ans;
        while(n != 0)
        {
            ans.insert(n);
            n=getnum(n);
            if(n==1)
                break;
            else if(ans.count(n))
                return !n;
        }
        return n;
    }
};

结算页面

相关推荐
南宫萧幕25 分钟前
自控PID+MATLAB仿真+混动P0/P1/P2/P3/P4构型
算法·机器学习·matlab·simulink·控制·pid
handler012 小时前
Linux: 基本指令知识点(2)
linux·服务器·c语言·c++·笔记·学习
故事和你912 小时前
洛谷-数据结构1-4-图的基本应用1
开发语言·数据结构·算法·深度优先·动态规划·图论
我叫黑大帅2 小时前
为什么map查找时间复杂度是O(1)?
后端·算法·面试
炽烈小老头2 小时前
【每天学习一点算法 2026/04/20】除自身以外数组的乘积
学习·算法
skilllite作者3 小时前
AI agent 的 Assistant Auto LLM Routing 规划的思考
网络·人工智能·算法·rust·openclaw·agentskills
py有趣4 小时前
力扣热门100题之不同路径
算法·leetcode
_日拱一卒5 小时前
LeetCode:25K个一组翻转链表
算法·leetcode·链表
啊哦呃咦唔鱼5 小时前
LeetCodehot100-394 字符串解码
算法
小欣加油5 小时前
leetcode2078 两栋颜色不同且距离最远的房子
数据结构·c++·算法·leetcode·职场和发展