当前位置: 首页 > article >正文

LeetCode:202. 快乐数

🍎道阻且长,行则将至。🍓

🌻算法,不如说它是一种思考方式🍀


算法专栏: 👉🏻123


一、🌱202. 快乐数

  • 题目描述:编写一个算法来判断一个数 n 是不是快乐数。
    「快乐数」 定义为:
    对于一个正整数,每一次将该数替换为它每个位置上的数字的平方和。
    然后重复这个过程直到这个数变为 1,也可能是 无限循环 但始终变不到 1。
    如果这个过程 结果为 1,那么这个数就是快乐数。
    如果 n 是 快乐数 就返回 true ;不是,则返回 false 。

  • 来源:力扣(LeetCode)

  • 难度:简单

  • 提示:
    1 <= n <= 231 - 1

  • 示例 1:
    输入:n = 19
    输出:true
    解释:
    12 + 92 = 82
    82 + 22 = 68
    62 + 82 = 100
    12 + 02 + 02 = 1

🌾关于获取数字的每一位元素

我们可以使用对10取余%的方法获取最后一位数组,所以取余在除循环到最后就可以得到每一位数字。

private static int[] geton(int n) {//返回存储个位、十位、百位......的数组
    int k=n,s = 0;
    while (k>0) {
        k=k/10;s++;
    }
    int[] ans=new int[s];
    for (int i = 0; i < s; i++) {
        ans[i]=n%10;
        n=n/10;
    }
    return ans;
}

🌴解题

对于这个题,我们先想到数字每一位平方和,看到平方我们就会觉得最后的走向可能有三种:最后返回到1最后无限循环到某个数列圈里最后越来越大
而题目中没有提到这个越来越大的可能,可以稍微推一下:一位数最大是9,平方是81,就是说一位会产生两位的下一个数;两位数最大是99,每一位平方和就是162,就是说两位会产生三位的下一个数;三位数最大是999,每一位平方和就是243,然而三位没有产生四位的下一个数;四位数最大是9999,每一位平方和就是324,然而四位却是产生三位的下一个数;…;所以说再大的数字最后平方和都会落入到三位数的区间
那么当平方和的过程中出现了前面出现的元素,必然就是走入了一个循环里,基于此可以如下解题:

1.hashSet

我们使用HashSet来存储平方和,每次都会看看是否出现过该数。

class Solution {
    public boolean isHappy(int n) {
        Set<Integer> s1=new HashSet<>();
        if(n==1)
            return true;
        while(n!=1){
            if(s1.contains(n)){//包含重复元素就会无限循环
                return false;
            }else {
                s1.add(n);
                //new n
                n=geton(n);
            }
        }
        return true;
    }

    private static int geton(int n) {//返回个位、十位、百位......平方
        int s = 0;
        while (n>0) {
            s+=(n%10)*(n%10);
            n=n/10;
        }
        return s;
    }
}

在这里插入图片描述


🌵Bug本是code常态,通过才是稀缺的意外!🌷

返回第一页。☝


☕物有本末,事有终始,知所先后。🍭

🍎☝☝☝☝☝我的CSDN☝☝☝☝☝☝🍓


http://www.kler.cn/a/3703.html

相关文章:

  • 如何使用 Pytest 断言测试 Python 异常处理
  • 如何在oracle关闭情况下如何修改spfile的参数
  • vulnhub靶场【IA系列】之Tornado
  • 第15章:Python TDD应对货币类开发变化(二)
  • Go-知识 版本演进
  • 2024年博客之星年度评选—创作影响力评审入围名单公布
  • 进程间通信【Linux】
  • 基于微信小程序+爬虫制作一个表情包小程序
  • 【数据结构】实现二叉树的基本操作
  • “中国李宁“,能否救李宁?
  • Python满屏表白代码
  • 到了这个年纪,就应该阅读Spring源码了,源码阅读指南-编译加运行
  • 如果大学能重来,我绝对能吊打90%的大学生,早知道这方法就好了
  • 【蓝桥杯_练习】
  • STA:时序检查 - reg2output型
  • Java语言-----封装、继承、抽象、多态、接口
  • Idea+maven+spring-cloud项目搭建系列--11 整合dubbo
  • 肠道菌群对药物,重金属,污染物,膳食化合物的代谢和健康效应
  • antd+vue——table组件字段排序——对象数组排序 中文排序——基础积累
  • 100天精通Python(可视化篇)——第81天:matplotlib绘制不同种类炫酷饼图参数说明+代码实战(自定义、百分比、多个子图、圆环、嵌套饼图)
  • C++语法(11)---- 模拟实现list
  • Python list列表删除元素的4种方法
  • 面试官:如何保证接口幂等性?一口气说了9种方法!
  • 史诗级详解面试中JVM的实战
  • C++智能指针
  • Python | 蓝桥杯系列文章总结+经典例题重做