算法: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;
    }
相关推荐
编程大师哥4 分钟前
Java web
java·开发语言·前端
小棠师姐7 分钟前
随机森林原理与实战:如何解决过拟合问题?
算法·机器学习·随机森林算法·python实战·过拟合解决
电商API_1800790524710 分钟前
大麦网API实战指南:关键字搜索与详情数据获取全解析
java·大数据·前端·人工智能·spring·网络爬虫
dasi022710 分钟前
Java 趣闻
java
C雨后彩虹11 分钟前
synchronized高频考点模拟面试过程
java·面试·多线程·并发·lock
JAVA+C语言12 分钟前
Java ThreadLocal 的原理
java·开发语言·python
lkbhua莱克瓦2419 分钟前
进阶-SQL优化
java·数据库·sql·mysql·oracle
行稳方能走远27 分钟前
Android java 学习笔记 1
android·java
kaico201828 分钟前
多线程与微服务下的事务
java·微服务·架构
zhglhy28 分钟前
QLExpress Java动态脚本引擎使用指南
java