Leetcode 202.快乐数(哈希容器来检测是否出现重复)
传送门:力扣
所学知识:
1.求和过程,去数值的单数操作,使用while(n)来操作。很强。
int getSum(int n) {
int sum = 0;
while (n) {
sum += (n % 10) * (n % 10);
n /= 10;
}
return sum;
}
2.通过unordered_set哈希容器来检测是否进入无限循环中。
if(set.find(sum)!=end()){
return false;
}
而且哈希容器所需要的内存空间比数组要高。所以并不是所有题目都无脑使用哈希容器
代码:
#define _CRT_SECURE_NO_WARNINGS 1
#include<iostream>
#include<unordered_set>
using namespace std;
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) {
unordered_set<int> set;
while (1) {
int sum = getSum(n);
if (sum == 1) {
return true;
}
// 如果这个sum曾经出现过,说明已经陷入了无限循环了,立刻return false
if (set.find(sum) != set.end()) {
return false;
}
else {
set.insert(sum);
}
n = sum;
}
}
};
int main() {
Solution solution;
cout << solution.isHappy(19) << endl;
}