稀碎从零算法笔记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;
    }
};

结算页面

相关推荐
Hello.Reader12 小时前
算法基础(十)——分治思想把大问题拆成小问题
java·开发语言·算法
koo36413 小时前
周报5.10
笔记
绛橘色的日落(。・∀・)ノ13 小时前
机器学习之评估与偏差方差分析
算法
消失的旧时光-194313 小时前
C语言对象模型系列(四)《Linux 内核里的 container_of 到底是什么黑魔法?》—— 一篇讲透 Linux 内核的“对象模型”核心技巧
linux·c语言·算法
AI_Ming14 小时前
从0开始学AI:层归一化,原来是这回事!
算法·ai编程
kdxiaojie14 小时前
U-Boot分析【学习笔记】(3)
linux·笔记·学习
WL_Aurora14 小时前
备战蓝桥杯国赛【Day 8】
算法·蓝桥杯
智者知已应修善业14 小时前
【51单片机模拟生日蜡烛】2023-10-10
c++·经验分享·笔记·算法·51单片机
MediaTea14 小时前
Scikit-learn:从数据到结构——无监督学习的最小闭环
人工智能·学习·算法·机器学习·scikit-learn
智者知已应修善业14 小时前
【51单片机如何让LED灯从一亮到八,再从八亮到一】2023-10-13
c++·经验分享·笔记·算法·51单片机