leetcode 202 快乐数

leetcode 202 快乐数

题目

编写一个算法来判断一个数 n 是不是快乐数。

「快乐数」 定义为:

对于一个正整数,每一次将该数替换为它每个位置上的数字的平方和。

然后重复这个过程直到这个数变为 1,也可能是 无限循环 但始终变不到 1。

如果这个过程 结果为 1,那么这个数就是快乐数。

如果 n 是 快乐数 就返回 true ;不是,则返回 false 。

题解

这题目是简单题,本身主要有两个点可以总结:

(1)循环的判断,可以采用hash表的方法,当结果出现过同时不为1的时候说明已经循环了,return false

(2)这里受某位大佬的思路指导,在本题中并没有限制空间,但是如果这个循环非常大的时候就会出现oom的情况。参考快慢指针解链表循环,其实快慢指针可以应用于所有的循环判断,用O(1)的空间复杂度实现对循环的判断。

见代码:

代码

cpp 复制代码
class Solution {
public:
    int get_num_pingfang(int n){
        int sum_ = 0;
        while(n){
            sum_ += (n%10)*(n%10);
            n = n/10;
        }
        return sum_;
    }
    bool isHappy(int n) {
        int slow=n, fast=n;
        do{
            slow = get_num_pingfang(slow);
            fast = get_num_pingfang(fast);
            fast = get_num_pingfang(fast);
        }while(slow!=fast);
        return slow==1;

    }
};
相关推荐
hansang_IR16 分钟前
【记录】AT_abc400模拟赛
c++·算法·模拟赛
iAkuya20 分钟前
(leetcode)力扣100 59括号生成(回溯||按括号序列的长度递归)
算法·leetcode·职场和发展
共享家952720 分钟前
双指针算法(一)
数据结构·算法·leetcode
十八岁讨厌编程21 分钟前
【算法训练营 · 二刷总结篇】回溯算法、动态规划部分
算法·动态规划
阿昭L23 分钟前
C++异常处理机制反汇编(二):32位下基本类型异常分析
c++·逆向工程
知识分享小能手23 分钟前
Oracle 19c入门学习教程,从入门到精通,VC++ + Oracle 实现汽配管理系统(21)
c++·学习·oracle
近津薪荼24 分钟前
优选算法——滑动窗口2(数组模拟哈希表)
c++·学习·算法
挖矿大亨25 分钟前
C++中const修饰成员函数
开发语言·c++
金枪不摆鳍26 分钟前
算法基础-哈希表
算法·哈希算法
渐暖°27 分钟前
【leetcode算法从入门到精通】9. 回文数
算法·leetcode·职场和发展