Demo20快乐数

复制代码
/**
 * 编写一个算法来判断一个数 n 是不是快乐数。
 * 「快乐数」 定义为:
 * 对于一个正整数,每一次将该数替换为它每个位置上的数字的平方和。
 * 然后重复这个过程直到这个数变为 1,也可能是 无限循环 但始终变不到 1。
 * 如果这个过程 结果为 1,那么这个数就是快乐数。
 * 如果 n 是 快乐数 就返回 true ;不是,则返回 false 。
 */
java 复制代码
public class Demo20 {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        System.out.println("请输入一个正整数");
        int n = sc.nextInt();
        if(n==1){
            System.out.println(n+"是快乐数");
        }
        Set<Integer> seen = new HashSet<>();
        while (!seen.contains(n)) {
            seen.add(n);
            n =getNext(n);
            if(n==1){
                System.out.println(n+"是快乐数");
                return;
            }
        }
        System.out.println(n+"不是快乐数");
    }


    public static int getNext(int n) {
        int totalSum = 0;

        while (n > 0) {
            totalSum += Math.pow(n % 10, 2);
            n /= 10;
        }

        return totalSum;
    }
}
相关推荐
学习永无止境@3 分钟前
灰度图像中值滤波算法实现
图像处理·算法·计算机视觉
Dream_sky分享5 分钟前
找类中字段属性不同工具类
java
ysa0510307 分钟前
斐波那契上斐波那契【矩阵快速幂】
数据结构·c++·笔记·算法
早睡的叶子8 分钟前
onnx模型数据结构分析,用于解析onnx模型
数据结构
@atweiwei8 分钟前
Go语言面试篇数据结构底层原理精讲(下)
数据结构·面试·golang
givemeacar10 分钟前
SpringBoot3.3.0集成Knife4j4.5.0实战
java
十六年开源服务商15 分钟前
家庭装修公司网站方案策划2026
java·开发语言
XiYang-DING20 分钟前
【Java】TOP-K问题
java·开发语言
CHANG_THE_WORLD21 分钟前
模拟解析:宽度数组 `[1,2,1]`,10个条目的 XRef 流
java·前端·算法
lixinnnn.25 分钟前
多源BFS:矩阵距离
算法·宽度优先