力扣刷题记录 -- JAVA--14-----202. 快乐数


一、题目

在这里插入图片描述

二、代码

class Solution 
{
    public boolean isHappy(int n) 
    {
       if(n == 1) return true;
       
       Set<Integer> sets = new HashSet<>();
       int temp_num = 0;
       temp_num = GetNextNum(n);
       System.out.println("temp_num "  +temp_num);

       while(temp_num!=1 )
       {
           temp_num = GetNextNum(temp_num);
           if(sets.contains(temp_num)) return false;
           else sets.add(temp_num);
       }


       return true;
    }
    public int GetNextNum(int n)
    {
        int temp = n;
        int sum = 0;
        int temp_every = 0;
        while(temp!=0)
        {
           temp_every =temp %10;
           temp = temp/10;
           sum += temp_every * temp_every;
        }

        return sum;
    }
}

三、运行结果

在这里插入图片描述

四、附录

二刷

class Solution 
{
    public boolean isHappy(int n) 
    {

       int temp_n = n;
       Set<Integer> set1 = new HashSet<>();
       while(n!=1)
       {
          int sum = 0;
          while(temp_n!=0) 
          {
              int temp = temp_n%10 ;
              temp_n = temp_n / 10 ;
              sum+= temp*temp;
          }
          temp_n = sum;
        //   System.out.println("  sum  " + sum);
           
          if(sum == 1) break;
          if(!set1.contains(sum)) set1.add(sum);
          else return false;  
       }
       return true;
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

@白圭

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值