每日一题(LeetCode)----哈希表--快乐数

每日一题(LeetCode)----哈希表–快乐数

1.题目(202. 快乐数)

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

「快乐数」 定义为:

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

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

示例 1:

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

示例 2:

输入:n = 2
输出:false

提示:

  • 1 <= n <= 231 - 1

2.解题思路

根据分析我们发现一个数不断替换,要么会变为1,要么会陷入一个循环

思路一:哈希表

1.创建一个哈希表(这里我们用unordered_set),用来存我们遍历过的数

2.进行判断, 如果这个数不为1且在哈希表中没有出现过,那么我们把这个数存到哈希表中,然后把这个数进行替换,接着继续判断替换后的那个 数 如果这个数为1或者在哈希表中出现过,那么我们结束判断,将当前的数与1进行比较,与1相等那么n就是快乐数,否则就是陷入了 循环,不是快乐数

思路二:快慢指针法

1.定义一个慢指针指向第一个数,定义一个快指针指向第一个数进行变换后的数,

2.进行判断, 如果快指针指向的数不为1,且快指针和慢指针没有相遇,那么快指针指向当前所指向的数进行两次变换之后的数,慢指针指向当前 所指向的数进行一次变换之后的数,重新进行判断 如果快指针指向的数为1或者快指针和慢指针相遇了,那么结束判断,将当前快指针指向的数与1进行比较,与1相等那么n就是快乐 数,否则就是陷入了循环,不是快乐数

思路三:数学法

根据分析,我们发现下一个值可能比自己大的最大数字必须低于 243。因此,我们知道任何循环都必须包含小于 243 的数字,用这么小的数字,编写一个能找到所有周期的强力程序并不困难。

如果这样做,会发现只有一个循环:4→16→37→58→89→145→42→20→4。所有其他数字都在进入这个循环的链上,或者在进入 1 的链上。

因此,我们可以硬编码一个包含这些数字的散列集,如果我们达到其中一个数字,那么我们就知道在循环中。

思路来源:力扣官方题解
链接:https://leetcode.cn/problems/happy-number/

3.写出代码

思路一的代码

class Solution {
public:int nextInteger(int n){int sum=0;while(n){int i=n%10;sum+=i*i;n/=10;}return sum;}bool isHappy(int n) {unordered_set<int> ma;while(n!=1&&ma.count(n)==0){ma.insert(n);n=nextInteger(n);}return n==1;}
};

思路二的代码

class Solution {
public:int nextInteger(int n){int sum=0;while(n){int i=n%10;sum+=i*i;n/=10;}return sum;}bool isHappy(int n) {int slow = n;int fast = nextInteger(n);while (fast != 1 && slow != fast) {slow = nextInteger(slow);fast = nextInteger(nextInteger(fast));}return fast == 1;}
};

思路三的代码

class Solution {
public:int nextInteger(int n){int sum=0;while(n){int i=n%10;sum+=i*i;n/=10;}return sum;}bool isHappy(int n) {unordered_set<int> ma{4,16,37,58,89,145,42,20};while(n!=1&&ma.count(n)==0){n=nextInteger(n);}return n==1;}
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/179132.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

nodejs接收前端分片并组合成完整文件

前端将文件分成多个块&#xff0c;并将每个块上传到服务器。 服务器使用Node.js创建一个HTTP服务器或Express服务器。 在服务器端&#xff0c;我们可以使用Multer或Busboy模块来处理上传的文件块。 在文件上传完成之后&#xff0c;我们可以使用fs模块的createWriteStream()方…

11.28 知识回顾(Web框架、路由控制、视图层)

一、 web 框架 1.1 web框架是什么&#xff1f; 别人帮咱们写了一些基础代码------》我们只需要在固定的位置写固定的代码--》就能实现一个web应用 Web框架&#xff08;Web framework&#xff09;是一种开发框架&#xff0c;用来支持动态网站、网络应用和网络服务的开发。这大多…

2020年6月9日 Go生态洞察:VS Code Go扩展加入Go项目

&#x1f337;&#x1f341; 博主猫头虎&#xff08;&#x1f405;&#x1f43e;&#xff09;带您 Go to New World✨&#x1f341; &#x1f984; 博客首页——&#x1f405;&#x1f43e;猫头虎的博客&#x1f390; &#x1f433; 《面试题大全专栏》 &#x1f995; 文章图文…

unity学习笔记10

一、生命周期函数 1.Awake() 调用时间&#xff1a;对象被激活或创建时。 用途&#xff1a;通常用于初始化对象的状态&#xff0c;获取组件引用或执行其他在脚本生命周期早期需要完成的任务。 2.OnEnable(): 调用时间&#xff1a;对象激活时&#xff0c;包括对象被创建和Se…

力扣150. 逆波兰表达式求值

栈 思路&#xff1a; 使用栈存放运算数&#xff1b;遍历 tokens&#xff0c;当遇到运算符时&#xff0c;2 次出栈得到运算数进行相应的运算&#xff0c;将运算结果入栈&#xff1b;最终的结果在栈顶上&#xff1b; class Solution { public:int evalRPN(vector<string>…

Python数据预处理详解

更多资料获取 &#x1f4da; 个人网站&#xff1a;ipengtao.com 数据预处理是数据科学中至关重要的步骤&#xff0c;它包括清洗、转换、归一化等操作&#xff0c;以使数据适合于机器学习模型的使用。Python提供了多种强大的库和工具&#xff0c;能够帮助进行数据预处理。本文将…

springmvc无法访问静态资源

解决方案 在spring-mvc.xml加入下面这些即可 <mvc:default-servlet-handler></mvc:default-servlet-handler> 配置原理 它的意思是 先安装springmvc的前端控制器来寻找路径&#xff0c;如果找不到就交由tomcat服务器寻找&#xff0c; 大伙都学过jsp&#xff0…

idea 2023使用技巧(一)

IntelliJ IDEA在业界被公认为最好的java开发工具之一。它能给你良好的开发体验。 idea版本号为2023.2.5。 1 基础操作 1.1索引 idea首次加载项目时&#xff0c;都会创建索引&#xff0c;创建索引的时间跟项目的文件多少成正比。idea的缓存和索引主要是用来加快文件查询&…

重装电脑后要做的操作

一. typora typora偏好设置 图片 : 与**同一级目录的assess文件

JVM 参数介绍

在一些规模稍大的应用中&#xff0c;Java虚拟机&#xff08;JVM&#xff09;的内存设置尤为重要&#xff0c;想在项目中取得好的效率&#xff0c;GC&#xff08;垃圾回收&#xff09;的设置是第一步。 PermGen space&#xff1a;全称是Permanent Generation space.就是说是永久…

LINQ-123之数据源前进一点点

之前提到满足一定条件的数据都可以成为LINQ的数据源&#xff0c;那么条件是什么&#xff1f; 实现接口 IEnumerable<T> 或IQueryable<T>&#xff0c;满足其一就可以使用LINQ。 使用LINQ对数据源可以做以下几类事&#xff1a; 1、获取数据源的一部分 2、获取数据…

计算机丢失vcomp140.dll是什么意思,如何解决与修复(附教程)

vcomp140.dll缺失的5种解决方法以及vcomp140.dll缺失原因 引言&#xff1a; 在日常使用电脑的过程中&#xff0c;我们可能会遇到一些错误提示&#xff0c;其中之一就是“vcomp140.dll缺失”。这个错误提示通常出现在运行某些程序或游戏时&#xff0c;给使用者带来了困扰。本文…

【Python3】【力扣题】367. 有效的完全平方数

【力扣题】题目描述&#xff1a; 【Python3】代码&#xff1a; 1、解题思路&#xff1a;Python函数。num的平方根 或者 num的0.5次幂。 知识点&#xff1a;float.is_integer(...)&#xff1a;判断浮点数的值是否等于整数。也可以&#xff1a;浮点数.is_integer()。 pow(a,b)&…

字符串左旋问题

问题描述&#xff1a;将一个字符串左旋n个字符 例如“abcd”左旋俩个字符得到“cdab” 法一&#xff1a;暴力循环法 左旋几个就循环几次 第一次循环&#xff0c;先将首字符a存放在临时变量中&#xff0c;然后将bcd分别向前移动一位&#xff0c;最后将a补加到字符串末尾&…

重新定义学习方式,河南开放大学的学习好帮手

作为一名出现代学者&#xff0c;我深深意识到学习的重要性&#xff0c;尤其是对于在职人士和远程教育学生来说。然而&#xff0c;长期以来&#xff0c;我一直困扰于找不到高质量的学习资源和题目。然而&#xff0c;幸运的是&#xff0c;我发现了一款名为“电大搜题”的微信公众…

2020年4月20日 Go生态洞察:2019年Go开发者调查结果

&#x1f337;&#x1f341; 博主猫头虎&#xff08;&#x1f405;&#x1f43e;&#xff09;带您 Go to New World✨&#x1f341; &#x1f984; 博客首页——&#x1f405;&#x1f43e;猫头虎的博客&#x1f390; &#x1f433; 《面试题大全专栏》 &#x1f995; 文章图文…

springcloud进销存管理系统源码

开发说明&#xff1a; jdk1.8&#xff0c;mysql5.7&#xff0c;idea&#xff0c;vscode springcloud springboot mybatis vue elementui 功能介绍&#xff1a; 后台管理&#xff1a; 统计分析&#xff1a;查看产品&#xff0c;采购&#xff0c;销售数量&#xff1b;统计近…

入门必读:Figma软件的功能和用途一览!

1、Figma软件是做什么的 Figma软件奠定了在线设计工具的形式&#xff0c;产品UI设计功能非常强大&#xff0c;Figma软件基于web操作&#xff0c;无论是macos、windows可以使用这个软件&#xff0c;即使有电脑、浏览器、网络&#xff0c;甚至软件也不需要下载&#xff0c;节省了…

周期串(Periodic Strings)

做了我两个小时&#xff0c;我真的裂开 之前已经发过一次了&#xff0c;走在回宿舍的路上突然发现有些情况并不适用&#xff0c;赶紧删掉了 题目如下&#xff1a; 如果一个字符串可以由某个长度为k的字符串重复多次得到&#xff0c;则称该串以k为周期。例如&#xff1a;abca…

Zotero | 取消翻译后自动添加笔记

目录 Step1&#xff1a;点击 “编辑” << “首选项” Step2&#xff1a;“翻译” << 取消勾选 “自动翻译批注” 在 Zetoro 中&#xff0c;选择颜色标记勾画的内容&#xff0c;将会自动生成一条笔记&#xff0c;如下图所示&#xff1a; 本人觉得很鸡肋&#xff0…