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;
    }
}
相关推荐
lihao lihao几秒前
进程地址空间
数据结构·c++·算法
七夜zippoe1 分钟前
应用安全实践(二):Spring Security核心流程与OAuth 2.0授权
java·安全·spring·security·oauth 2.0
Byte不洛1 分钟前
LeetCode双指针经典题
c++·算法·leetcode·双指针
ch.ju2 分钟前
Java程序设计(第3版)第二章——java的数据类型:整数
java
程序员清风2 分钟前
AI编程最佳实践:一个AI写代码,另一个AI查Bug!
java·后端·面试
汀、人工智能2 分钟前
[特殊字符] 第16课:最小覆盖子串
数据结构·算法·数据库架构·图论·bfs·最小覆盖子串
计算机学姐5 分钟前
基于SpringBoot的高校餐饮档口管理系统
java·vue.js·spring boot·后端·spring·intellij-idea·mybatis
米粒16 分钟前
力扣算法刷题 Day 34
算法·leetcode·职场和发展
Lyyaoo.10 分钟前
【设计模式】工厂模式
java·开发语言·设计模式
派大星酷12 分钟前
Java 网络编程全解:TCP、UDP、HTTP、WebSocket
java·网络·tcp/ip