ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

202、快乐数

2021-11-22 18:31:59  阅读:131  来源: 互联网

标签:10 202 int sum Kuaileshu 快乐 public


题目:

编写一个算法来判断一个数 n 是不是快乐数。

「快乐数」定义为:对于一个正整数,每一次将该数替换为它每个位置上的数字的平方和,然后重复这个过程直到这个数变为 1,也可能是 无限循环 但始终变不到 1。如果 可以变为  1,那么这个数就是快乐数。

如果 n 是快乐数就返回 True ;不是,则返回 False 。

思路:

将每次计算的sum记录下来,如果出现重复的sum值就可以判断无法得到快乐数,如果没有重复的sum值,那么说明这个计算会一直进行下去直到找到sum=1;

public class Kuaileshu {
    //取各位数的单数平方的和
    public int getSum(int n){
        int sum = 0;
        while(n>0){
            sum +=(n%10)*(n%10);
            n/=10;
        }
        return sum;
    }

    public boolean isHappy(int n){
        Set<Integer> record = new HashSet<>();
        //如果平方的和不等于1并且集合中不存在平方和
        //就将本次平方的和存入集合中
        while( n!= 1 && !record.contains(n)){
            record.add(n);
            n = getSum(n);
        }
        return n==1;
    }

    public static void main(String[] args) {
        Kuaileshu kuaileshu = new Kuaileshu();
        boolean res = kuaileshu.isHappy(19);
        System.out.println(res);
    }
}

输出结果: 

True

标签:10,202,int,sum,Kuaileshu,快乐,public
来源: https://blog.csdn.net/CoCo629vanilla/article/details/121477243

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有