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;
    }
}
相关推荐
一叶落4382 分钟前
【LeetCode 12】整数转罗马数字(C语言)| 贪心算法详解
c语言·数据结构·c++·算法·leetcode·贪心算法
2401_838683372 分钟前
单元测试在C++项目中的实践
开发语言·c++·算法
凤山老林2 分钟前
Tomcat 高高在上?0-1 实现一个简单的 WEB 容器
java·后端·tomcat·web容器
_BugMan2 分钟前
【SSE】
java·servlet·tomcat
014-code3 分钟前
kafka + springboot快速入门
java·spring boot·分布式·kafka
盐水冰6 分钟前
【烘焙坊项目】后端搭建(11)- 用户&商家订单板块
java·后端·学习
吧啦蹦吧7 分钟前
idea---------------
java·ide·intellij-idea
一叶落4389 分钟前
【LeetCode 289】生命游戏(C语言)|原地算法 + 状态标记法
c语言·数据结构·算法·leetcode·游戏
李白的粉10 分钟前
基于springboot的教师工作量管理系统
java·spring boot·毕业设计·课程设计·教师工作量管理系统·源代码
武超杰11 分钟前
SpringMVC入门指南:从零开始掌握核心用法
java·spring·mvc