1 问题
编写一个算法来判断一个数 n 是不是快乐数。
「快乐数」定义为:对于一个正整数,每一次将该数替换为它每个位置上的数字的平方和,然后重复这个过程直到这个数变为 1,也可能是 无限循环 但始终变不到 1。如果 可以变为 1,那么这个数就是快乐数。
如果 n 是快乐数就返回 True ;不是,则返回 False 。
示例:
输入:19
输出:true
解释:
12 + 92 = 82
82 + 22= 68
62+ 82 = 100
12 + 02 + 02 = 1
2 解法
考察两个知识点:
1.如何求数的各个位置的和。
2.如何判断sum有没有重复出现过,一旦重复出现过就会无限循环下去,即不是快乐数。
当我们遇到了要快速判断一个元素是否出现集合里的时候,就要考虑哈希法了。
判断sum是否重复出现就可以使用unordered_set。
class Solution {
public:
//对某数各个位置求平方和
int getSum(int n){
int sum = 0;
while(n)
{
//计算低位平方和
sum += (n % 10) * (n % 10);
//移除低位
n /= 10;
}
return sum;
}
bool isHappy(int n) {
//定一个无序集合,存放sum
unordered_set<int> sum_set;
//sum!=1,或sum未出现过时循环计算
while(1)
{
int sum = getSum(n);
//sum==1,为快乐数
if(sum == 1)
{
return true;
}
//判断sum是否在集合中出现过
//未出现过,则在集合中添加新的sum,继续求和
if(sum_set.find(sum) == sum_set.end())
{
sum_set.insert(sum);
}
//若出现过,则会一直循环下去,不是快乐数
else
return false;
//更新n
n = sum;
}
//退出循环则sum=1,是快乐数
return true;
}
};