专题一 - 双指针 - leetcode 202. 快乐数 | 简单难度

leetcode 202. 快乐数

  • leetcode 202. 快乐数 | 简单难度
    • 1. 题目详情
      • 1. 原题链接
      • 2. 基础框架
    • 2. 解题思路
      • 1. 题目分析
      • 2. 算法原理
      • 3. 时间复杂度
    • 3. 代码实现
    • 4. 知识与收获

在这里插入图片描述

leetcode 202. 快乐数 | 简单难度

1. 题目详情

编写一个算法来判断一个数 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

1. 原题链接

leetcode 202. 快乐数

2. 基础框架

● Cpp代码框架

class Solution {
public:
    bool isHappy(int n) {

    }
};

2. 解题思路

1. 题目分析

( 1 ) (1) (1) 判断一个整数n是否是快乐数:用该数的每个位置的平方和作为新值,一直进行下去,如果最终能得到1就返回false,反之无限循环就返回fasle。
( 2 ) (2) (2) 本题出现的无限循环指的是一个数变成一系列不同的数,直到又变成自身,然后循环往复,这个无限循环中的每个数是确定的。
( 3 ) (3) (3)

2. 算法原理

( 1 ) (1) (1) 首先想到的是一种解法:
模拟数n的变化过程,同时使用哈希表记录每次变化的新数new_n,判断每次变化的新数new_n是否是1
如果是1就是快乐数;
如果不是1就在哈希表中查找new_n自身是否已经出现过了:
————如果在哈希表中找到了自身就说明new_n出现过了,且new_n不是1,说明已经进入无限循环了,即数n一定不是快乐数;
继续变化得到下一个new_n,循环判断。
在这里插入图片描述

( 2 ) (2) (2) 第二种解法:快慢指针算法
你知道判断链表是否有环这道题是如何做的呢?
链表是否有环这道题使用了快慢双指针,慢slow每次走1步,快指针fast每次走两步,如果链表有环,最终slowfast会相遇即slow==fast

本题中n数n的变化也可以转换为与求链表是否有环中相类似的情况:
对于数n
情况1:不是快乐数,n经过一系列数的变化最终会变回已经出现的数,然后又从从已经出现得数开始再继续变化,形成无限循环,形象的说就是进入了环;

情况2:如是快乐数,n经过一系列数的变化最终会变到1,而1如果继续变化,那么会一直会回1本身,此时也可以说进入了无限循环,只不过这个无限循环中变化的数都是1本身;

上面两种情况就可以合并为一种情况:数n经过一系列变化,进入循环,快指针fast一次走2步(这里的走两步是形象的说法,实际上表示的是fast变化了两次),慢指针slow一次走1步,最终会进入环,在环中快慢指针最终一定会相遇:
判断两者的值是否相等,相等时说明相遇了,
————然后判断快慢指针的值是否是1
————————如果是1则是快乐数;反之不是快乐数。
在这里插入图片描述

3. 时间复杂度

为了使用n描述时间复杂度,下文描述数n时将会换成数num。

第一种解法 模拟: O ( n ) O(n) O(n),但借助了额外n的空间。

数num的变化长度是确定的,不管是变为1还是进入无限循环。
每次都会记录数num的变化,所以相当于遍历了一遍num的所有变化情况。

第二种解法 快慢指针: O ( n ) O(n) O(n)

3. 代码实现

解法一:模拟

class Solution {
public:
    int change(int val){
        int ret = 0;
        while(val){
            int mod = val % 10;
            ret += mod * mod;
            val /= 10;
        }
        return ret;
    }
    bool isHappy(int n) {
        unordered_set<int> us;// 哈希表存储每次出现的新数

        // 模拟n的变化
        while(n != 1){
            if(us.find(n) != us.end()) return false;
            us.insert(n);
            n = change(n);
        }
        return true;
    }
};

解法二:快慢双指针

class Solution {
public:
    int change(int val){
        int newval = 0;
        while(val){
            int mod = val % 10;
            val /= 10;
            newval += mod * mod; 
        }
        return newval;
    }
    bool isHappy(int n) {
        int slow = n, fast = n;
        do{
            slow = change(slow);
            fast = change(fast);
            fast = change(fast);
        } while(slow != fast);
        return slow == 1;
    }
};

4. 知识与收获

( 1 ) (1) (1) 快慢双指针的应用中,判断是否有环链表是一道经典的题目,本题虽然表面上与其无关,但是在分析之后发现有很大的相关性,也就可以使用快慢指针思路解决了。


T h e The The E n d End End

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

linux守护程序

概述 周末还要加班写代码&#xff0c;偷个懒发个刚刚写的守护进程&#xff0c;有一个小bug懒得处理&#xff0c;急着要用&#xff0c;发出来记录一下成果。 守护程序 网上很多介绍的&#xff0c;大家有兴趣自己去查查 上酸菜 #include <stdio.h> #include <stdli…

代码随想录刷题笔记-Day32

1. 最大子序和 53. 最大子数组和https://leetcode.cn/problems/maximum-subarray/ 给你一个整数数组 nums &#xff0c;请你找出一个具有最大和的连续子数组&#xff08;子数组最少包含一个元素&#xff09;&#xff0c;返回其最大和。 子数组&#xff1a;是数组中的一个连续…

Java学习笔记NO.18

T1.理工超市 &#xff08;1&#xff09;题目描述 编写一个程序&#xff0c;设计理工超市功能菜单并完成注册和登录功能的实现。显示完菜单后&#xff0c;提示用户输入菜单项序号。当用户输入<注册>和<登录>菜单序号时模拟完成注册和登录功能&#xff0c;最后提示…

多态的原理

通过监视可以发现&#xff0c;基类和子类的虚表指针指向的是不同的虚表&#xff08;监视窗口可以证实&#xff09;&#xff0c;而且虚表里面的函数地址也是不一样的。这就符合我们的预期了&#xff0c;因为多态的调用的时候&#xff0c;就是通过虚表指针去找到对应虚表里面的虚…

蓝桥杯练习系统(算法训练)ALGO-981 过河马

资源限制 内存限制&#xff1a;256.0MB C/C时间限制&#xff1a;1.0s Java时间限制&#xff1a;3.0s Python时间限制&#xff1a;5.0s 问题描述 在那个过河卒逃过了马的控制以超级超级多的走法走到了终点之后&#xff0c;这匹马表示它不开心了……   于是&#xff0c…

[2024-03-09 19:55:01] [42000][1067] Invalid default value for ‘create_time‘【报错】

这个错误可能是因为你的 MySQL 数据库版本不支持 CURRENT_TIMESTAMP 作为默认值。在一些早期版本中&#xff0c;MySQL 对 TIMESTAMP 类型字段的默认值设置有限制&#xff0c;只允许使用特定的常量值&#xff08;如 0000-00-00 00:00:00 或 CURRENT_TIMESTAMP()&#xff09;。如…

王道机试C++第 4 章 字符串:字符串内容续写几个小程序 Day30

统计字符 习题描述 统计一个给定字符串中指定的字符出现的次数。 输入描述&#xff1a; 测试输入包含若干测试用例&#xff0c;每个测试用例包含2行&#xff0c;第1行为一个长度不超过5的字符串&#xff0c;第2行为一个长度不超过80的字符串。注意这里的字符串包含空格&…

浅述字典攻击

一、前言 字典攻击是一种常见的密码破解方法&#xff0c;它使用预先编制的字典文件作为攻击字典&#xff0c;通过尝试猜测密码的方式来破解密码。下面是一个关于字典攻击的博客&#xff0c;希望能够为您了解字典攻击提供帮助。 二、字典攻击概述 字典攻击是一种密码破解方法&…

poetry库:依赖管理和打包工具

这个工具是在群里看见别人说好用的&#xff0c;所以了解一下。 1.poetry初始 官网&#xff1a;https://python-poetry.org/ 项目仓库&#xff1a;https://github.com/python-poetry 或 https://github.com/python-poetry/poetry 教程&#xff1a;https://python-poetry.org/…

为什么网络安全人才缺口这么大,但还是有很多人找不到工作?

为什么央视说到2027年我国网络安全人员缺口达327万&#xff0c;但是还是有很多人找不到工作。 今年大家听到“就业大环境很差”、“工作不好找”之类的太多了。如今大环境已经逐渐好转&#xff0c;虽然不需要太过焦虑&#xff0c;但是也要持续的提升自己。 最近有听华为的渗透…

杨辉三角(C语言)

杨辉三角 一.什么是杨辉三角 一.什么是杨辉三角 每个数等于它上方两数之和。 每行数字左右对称&#xff0c;由1开始逐渐变大。 第n行的数字有n项。 前n行共[(1n)n]/2 个数。 … 当前行的数上一行的数上一行的前一列的数 void yanghuisanjian(int arr[][20], int n) {for (int i…

SpringBoot源码

SpringBoot核心前置内容 1.Spring注解编程的发展过程 1.1 Spring 1.x 2004年3月24日&#xff0c;Spring1.0 正式发布&#xff0c;提供了IoC&#xff0c;AOP及XML配置的方式。 在Spring1.x版本中提供的是纯XML配置的方式&#xff0c;也就是在该版本中必须要提供xml的配置文件…

夏泽网注册码

夏泽网注册码申请法:1.打开注册码申请页&#xff0c;http://nianjian.xiaze.com/getcode.php 上面会显示你的注册码链接 (是个红色的链接,不同的时间不同的人这个链接不一样)。 2.将注册码链接以超链接的方式发布在各大网站、论坛、博客&#xff08;支持各大论坛、百度空间、 网…

117.龙芯2k1000-pmon(16)- linux下升级pmon

pmon的升级总是有些不方便&#xff0c;至少是要借助串口和串口工具 如果现场不方便连接串口&#xff0c;是不是可以使用网线升级pmon呢&#xff1f; 答案当然是可行的。 环境&#xff1a;2k1000linux3.10麒麟的文件系统 如今我已经把这个工具开发出来了。 GitHub - zhaozhi…

如何开通 GitHub Sponsors

Github Sponsors 是什么&#xff1f; 简单来说&#xff0c;GitHub Sponsors 是一个赞助服务&#xff0c;它允许个人和组织直接向开源贡献者和项目提供财务赞助&#xff0c;以便于有更多的时间和资源来专注于自己的开源工作。 这对于开源贡献者来说是非常棒&#x1f389;的&…

Swift 入门学习:集合(Collection)类型趣谈-下

概览 集合的概念在任何编程语言中都占有重要的位置&#xff0c;正所谓&#xff1a;“古来聚散地&#xff0c;宿昔长荆棘&#xff1b;游人聚散中&#xff0c;一片湖光里”。把那一片片、一瓣瓣、一粒粒“可耐”的小精灵全部收拢、吸纳的井然有序、条条有理&#xff0c;怎能不让…

008-slot插槽

slot插槽 1、插槽 slot 的简单使用2、插槽分类2.1 默认插槽2.2 具名插槽2.3 作用域插槽 插槽就是子组件中的提供给父组件使用的一个占位符&#xff0c;用<slot></slot> 表示&#xff0c;父组件可以在这个占位符中填充任何模板代码&#xff0c;如 HTML、组件等&…

【Docker】容器的生态系统

Docker提供了一整套技术支持&#xff0c;包括核心技术、平台技术、支持技术。 核心技术 容器核心技术是指能让Container&#xff08;容器&#xff09;在host&#xff08;集群、主机&#xff09;上运行起来的那些技术。 1&#xff09;容器规范&#xff1a;OCI&#xff08;runt…

round四舍五入在python2与python3版本间区别

round()方法返回数值的小数点四舍五入到n个数字。 语法 以下是round()方法的语法&#xff1a; round( x ,n) 参数 x --这是一个数值&#xff0c;表示需要格式化的数值 n --这也是一个数值,表示小数点后保留多少位 返回值 该方法返回 数值x 的小数点四舍五入到n个数字 …

计算机设计大赛 疲劳驾驶检测系统 python

文章目录 0 前言1 课题背景2 Dlib人脸识别2.1 简介2.2 Dlib优点2.3 相关代码2.4 人脸数据库2.5 人脸录入加识别效果 3 疲劳检测算法3.1 眼睛检测算法3.2 打哈欠检测算法3.3 点头检测算法 4 PyQt54.1 简介4.2相关界面代码 5 最后 0 前言 &#x1f525; 优质竞赛项目系列&#x…