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

DAY 35 leetcode 202--哈希表.快乐数

题号202

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

「快乐数」 定义为:

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

如果 n 是 快乐数 就返回 true ;不是,则返回 false 。

我的失败写法

/*

class Solution {
    public boolean isHappy(int n) {
        String numstr=String.valueOf(n);//用自带函数将其转换为字符串
        int ans=0;
        while(ans!=1){
            ans=0;
            for(int i=0;i<numstr.length();i++){
                ans+=(numstr.charAt(i)-'0')*(numstr.charAt(i)-'0');
            }
            numstr=String.valueOf(ans);
            if(ans==1)
            return true;
        }
        return false;//缺点是遇到循环无法跳出
    }
}

*/

改进后

class Solution {
    public boolean isHappy(int n) {
        String numstr=String.valueOf(n);
        int ans=0;
        Set<Integer> set=new HashSet<Integer>();//用哈希集合来记录
        while(ans!=1){
            ans=0;
            for(int i=0;i<numstr.length();i++){
                ans+=(numstr.charAt(i)-'0')*(numstr.charAt(i)-'0');
            }
            numstr=String.valueOf(ans);
            if(!set.contains(ans))//如果集合中不存在该数,则添加
            set.add(ans);
            else//若存在,说明已经有循环,则为无限循环,返回false
            return false;         
        }
        return true;
    }
}

改进的关键在于,知道如何判断出现了无限循环:即产生了已经出现过的数字

再改进版

class Solution {
    public boolean isHappy(int n) {     
        Set<Integer> set=new HashSet<Integer>();
        while(getResult(n)!=1){
            if(set.contains(getResult(n)))
            return false;
            else
             {
            set.add(getResult(n));
            n=getResult(n);
            }
        }
        return true;
    }
    public int getResult(int n){
        int sum=0;
        while(n!=0){
            int a=n%10;//对10取模 得出个位的数字
            n/=10;//n除以10 自动更新为去除掉个位
            sum+=a*a;
        }
        return sum;
    }
}

此时改进了对于求每个数字平方和的算法:不必每一位均记录下来,数位分离的方法,可采用先对10求模再除以10更新自身的方法。

快慢指针法

class Solution {
    public boolean isHappy(int n) {
        
        int slow=n;
        int fast=getNext(n);
        while(fast!=1){
            slow=getNext(slow);
            fast=getNext(getNext(fast));
            if(slow==fast)
            return false;
        }
        return true;
    }
    public int getNext(int n){
        int sum=0;
        while(n!=0){
            int a=n%10;//对10取模 得出个位的数字
            n/=10;//n除以10 自动更新为去除掉个位
            sum+=a*a;
        }
        return sum;
    }
}

即在上一个解法中搞清楚这题关键是要判断有没有循环后,我们的任务就成了熟悉的判断是否有循环,DAY 31 leetcode 142--链表.环形链表-CSDN博客在这一篇中我们已经学习过在链表里面处理循环问题,而判断是否有环更简单,只需要fast指针和slow指针相遇即可(fast一次走两步,slow一次走一步)而此题中,通过反复调用 getNext(n) 得到的链是一个隐式的链表。可以使用这种方法。

http://www.dtcms.com/a/109449.html

相关文章:

  • QT 非空指针 软件奔溃
  • 检索增强生成(RAG) 优化策略
  • LLM架构解析:长短期记忆网络(LSTM)(第三部分)—— 从基础原理到实践应用的深度探索
  • MyBatis:开源、轻量级的数据持久化框架
  • 游戏引擎学习第201天
  • Muduo网络库实现 [九] - EventLoopThread模块
  • 康谋分享 | 仿真驱动、数据自造:巧用合成数据重构智能座舱
  • 去中心化交易所(DEX)
  • Unity3D开发AI桌面精灵/宠物系列 【三】 语音识别 ASR 技术、语音转文本多平台 - 支持科大讯飞、百度等 C# 开发
  • 【GCC警告报错4】warning: format not a string literal and no format arguments
  • 从扩展黎曼泽塔函数构造物质和时空的结构-13
  • 练习题:120
  • 【Linux学习笔记】开发工具git和gbd和cgbd的介绍和使用
  • PADS 9.5【附破解文件+安装教程】中文激活版下载
  • IP分片攻击实战模拟
  • 蓝桥杯真题——传送阵
  • xsync脚本是一个基于rsync的工具
  • LN2220 2A 高效率升压 DC/DC 电压调整器
  • 前端面试题(二):vue2中v-if和v-show的区别
  • 使用python完成手写数字识别
  • 列表某个字段由多个值组成,使用id匹配展示
  • Angular 项目 PDF 批注插件库在线版 API 示例教程
  • 儿童语义认知功能磁共振成像研究的元分析
  • Python+Playwright自动化测试-1-环境准备与搭建
  • 【爬虫开发】爬虫开发从0到1全知识教程第14篇:scrapy爬虫框架,介绍【附代码文档】
  • [原创](Modern C++)现代C++的关键性概念: 什么是左值?
  • 运维之 Centos7 防火墙(CentOS 7 Firewall for Operations and Maintenance)
  • 17、Swift框架微调实战(2)-QWQ-32B LORA微调cot数据集
  • 加密解密工具箱 - 专业的在线加密解密工具
  • 19-元素显示模式及浮动(CSS3)