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;
}

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
THE END
分享
二维码
< <上一篇
下一篇>>