算法: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;
    }
相关推荐
baizhigangqw16 分钟前
启发式算法WebApp实验室:从搜索策略到群体智能的能力进阶
算法·启发式算法·web app
IGAn CTOU23 分钟前
王炸级更新!Spring Boot 3.4 正式发布,新特性真香!
java·spring boot·后端
C雨后彩虹30 分钟前
最多等和不相交连续子序列
java·数据结构·算法·华为·面试
tycooncool39 分钟前
Spring中的IOC详解
java·后端·spring
014-code1 小时前
日志规范:怎么写才不算写废话
java·开发语言·设计模式·日志
CQU_JIAKE1 小时前
4.17[Q]
java·linux·服务器
cpp_25011 小时前
P2347 [NOIP 1996 提高组] 砝码称重
数据结构·c++·算法·题解·洛谷·noip·背包dp
Hugh-Yu-1301231 小时前
二元一次方程组求解器c++代码
开发语言·c++·算法
亦暖筑序2 小时前
Spring AI Alibaba 报错合集:我踩过的那些坑
java·后端
编程大师哥2 小时前
C++类和对象
开发语言·c++·算法