Python 快乐数

快乐数,也不多说它的定义了,直接说相关的概念吧,如下:

  • 所有不快乐数的数位平方和计算,最后都会进入 4 → 16 → 37 → 58 → 89 → 145 → 42 → 20 → 4 的循环中
  • 已知规律: [1 ~ 4] 中只有 1 是快乐数,[5 ~ ∞] 的数字要么回归到 1 要么回归到 4 或 3
    其实,看到这两条规律就很明显了,我们求一个数的数位平方和,然后判断是否等于1或者4,如果等于1,返回True,如果等于4,返回False如果都不等于,不代表什么,我们接着进行求和,代码如下:
 def isHappy(self, n: int) -> bool:
        while True:
            n = sum([int(i) ** 2 for i in str(n)])
            if n == 4:
                return False
            if n == 1:
                return True

是不是感觉过于简洁了,其实很简单,一直循环,无论是不是快乐数,必然会有等于1或者4的时候,只要这个时候到了,就结束了循环,就这么简单。
说实话,我感觉这是我见过的快乐数最狂暴的解法,下面是一道leetcode上的快乐数的题,大家可以试试
快乐数

おすすめ

転載: blog.csdn.net/weixin_45659364/article/details/116084617