算法:3.快乐数

202. 快乐数 - 力扣(LeetCode)

双指针

解法思路:如图

根据如图原理,我们可以使用快慢指针轻松且愉快的高效解决问题。

【不了解快慢指针的看这里】快慢指针原理很简单,想像一下你和你女朋友一起在赛道同时起跑,你的速度肯定是更快的(假设你一步等于她两步),那么你们两个最快遇见的时候是你跑了两圈而她只跑了一圈(原理:你的路程是她的两倍时相遇)。

我们定义slow和fast指针,fast的速度是slow的两倍,不要考虑3倍或n倍,可能会出问题,想要了解问什么不能n倍可以查一查,这里不做讲解

代码实现:

java 复制代码
public int sum(int n){
        int num=0;
        while(n!=0){
            num+=Math.pow(n%10,2);
            n/=10;
        }
        return num;
    }

    public boolean isHappy(int n){
        int slow = n;
        int fast = sum(n);
        while(slow!=fast){
            slow=sum(slow);
            fast=sum(sum(fast));
        }
        return slow==1;
    }
相关推荐
Zzxy2 小时前
HikariCP连接池
java·数据库
我带你来这儿就是为了告诉你我2 小时前
C++23新特性前瞻
开发语言·c++·算法
陌夏2 小时前
快速排序 (Quick Sort)
算法
罗超驿2 小时前
Java数据结构_栈_算法题
java·数据结构·
希望永不加班2 小时前
SpringBoot 主启动类解释:@SpringBootApplication 到底做了什么
java·spring boot·后端·spring
IronMurphy2 小时前
【算法二十九】 437. 路径总和 III
算法·深度优先
2501_908329852 小时前
C++安全编程指南
开发语言·c++·算法
计算机安禾2 小时前
【C语言程序设计】第39篇:预处理器与宏定义
c语言·开发语言·c++·vscode·算法·visual studio code·visual studio
m0_569881472 小时前
C++中的装饰器模式变体
开发语言·c++·算法
笒鬼鬼2 小时前
【API接口】最新可用红果短剧接口
算法·api·笒鬼鬼·红果短剧·接口源码