C语言每日一题(64)快乐数

题目链接

力扣网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

思路分析

知识点:双指针、快慢指针

解析:

从题目开始分析,第一句话,对于一个正整数,每一次将该数替换为它每个位置上的数字的平方和。没什么好说的,很简单;第二句话:然后重复这个过程直到这个数变为 1,也可能是 无限循环 但始终变不到 1,什么意思?

我们看示例1,你看着它的运算过程,发现它最终等于1,是快乐数,

但示例2没有运算过程,直接输出false,就不好分析为什么错误,那我们用上面的方法对他进行一下运算看看。

当我们把过程中出现的每一个数用画图的形式表现出来时,我们发现,2开头,最后从4开始进入循环,很想以前我们做过的判断带环链表,所以可以用快慢指针法来改进一下

环形链表详解

方法步骤

1.定义两个快慢指针,但此指针非比指针,而是每个阶段的值,slow走一步,fast走两步。

当它们相遇时,再判断其中一值是否为1即可。

代码

(建议自己去实现一下再看会比较好)

int bitsum(int n) {//求各位上的数的平方和int sum = 0;while (n) {int j = n % 10;sum += j * j;n /= 10;}return sum;
}bool isHappy(int n) {int fast = n, slow = n;do {slow = bitsum(slow);fast = bitsum(bitsum(fast));} while (slow != fast);return slow == 1;
}

拓展

在前面我们漏了一个关键点没有考虑,就是这个方法实现的基础是这段数据组成的链表(逻辑上)是有环的,我们怎么肯定这段数据是带环的呢?

这里介绍一个数学原理:鸽巢原理

鸽巢原理,也被称为抽屉原理、鸽笼原理,是一种基本的计数原理,用来描述在一定条件下的排列组合问题。

鸽巢原理的形象解释是:如果有 n 个鸽子被放入 m 个鸽巢中,其中 n > m,那么至少有一个鸽巢中会有多于一个鸽子。

在数学上,鸽巢原理的一般形式是:如果有 n+1 个对象被放入 n 个容器中,那么至少有一个容器中会包含两个或更多的对象。

鸽巢原理的应用范围广泛,包括组合数学、概率论、计算机科学等领域。它可以用于解决各种问题,如证明存在性、推理、计数等。

鸽巢原理的应用举例:
1. 在一周的七天里,如果有八个人生日,那么至少有两个人生日在同一天。
2. 在一台有 30 个存储单元的计算机中,如果有 31 个数据需要存储,那么至少有两个数据会存储在同一存储单元中。

基于鸽巢原理,我们来证明一下这道题的任意数据是必定带环的。

这道题数据的取值范围是2的31次方-1,转换一下等于2147483647,我们取到数字个数的最大值,即9999999999,可以推导出,这个数通过题目的方法取到的数,一定是最大的(因为原数比范围还大,同时也是各位上的最大值),即81*10=810,所以,测试样例的变化范围就在【1,810】之间,不会有大于它的数存在。

设需要检测的数为x,假设最坏情况,它变化了810次都没有重复的数存在,说明它已经将1——810的数已经遍历完一遍,当进行第811次时,必定有重复值出现。

可以将1——810看成鸽巢,x的变化次数为鸽子。

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

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

相关文章

Flink源码解析(1)job启动,从JM到TM过程详解

网络传输模型 首先在看之前,回顾一下akka模型: Flink通讯模型—Akka与Actor模型-CSDN博客 注:ActorRef就是actor的引用,封装好了actor 下面是jm和tm在通讯上的概念图: RpcGateway 不理解网关的作用,可以先移步看这里:网关_百度百科 (baidu.com) 用于定义RPC协议,是…

【Python】【Pandas】详解Pandas模块常用函数

1. pandas简介 Pandas 是一个开源的第三方 Python 库,从 Numpy 和 Matplotlib 的基础上构建而来,享有数据分析“三剑客之一”的盛名(NumPy、Matplotlib、Pandas)。Pandas 已经成为 Python 数据分析的必备高级工具,它的目标是成为强大、灵活、可以支持任何编程语言的数据分…

torchvision pytorch预训练模型目标检测使用

参考&#xff1a; https://pytorch.org/vision/0.13/models.html https://blog.csdn.net/weixin_42357472/article/details/131747022 有分类、检测、分割相关预训练模型 1、目标检测 https://pytorch.org/vision/0.13/models.html#object-detection-instance-segmentation-…

四.流程控制(顺序,分支,循环,嵌套)

c刚刚转过来的记得写在public static void main&#xff08;String[] args&#xff09;的花括号里 一.顺序结构 二.分支结构 if &#xff0c;switch 1.if (条件判断&#xff09; 2.if else 3.if else if else if ... else(它是一个一个否定来一个个执行判断的 4.s…

以太坊开发学习-solidity(三)函数类型

目录 函数类型 函数类型 solidity官方文档里把函数归到数值类型 函数类型是一种表示函数的类型。可以将一个函数赋值给另一个函数类型的变量&#xff0c; 也可以将一个函数作为参数进行传递&#xff0c;还能在函数调用中返回函数类型变量。 函数类型有两类&#xff1a;- 内部&…

什么是虚拟dom

Virtual DOM&#xff08;虚拟DOM&#xff09; 就是由普通的 JS 对象来描述DOM对象&#xff0c;因为不是真实的DOM对象&#xff0c;所以叫 Virtual DOM。 虚拟DOM就是使用一个虚拟的 DOM 树来描述真实的 DOM 树结构和节点属性&#xff0c;通过比较新旧两颗虚拟 DOM 树的差异&…

如何删除全局的某个字符并替换js

let cons data[i].content.replace(/\/uploads\//g, 要替换的字符串/);console.log(data[i]); 该代码是将data数组中每个元素的content属性值中的"/uploads/"替换为"http://bas.xingyuncm.cn/uploads/"。 其中&#xff0c;replace()方法是字符串的方法&am…

day-24 腐烂的橘子

思路&#xff1a;利用bfs的思想 首先利用bfs遍历值为2的橘子&#xff08;遍历时1和2都可以走&#xff09;结束后如果存在某个橘子未被访问过且值为1则返回-1 再利用bfs遍历值为2的橘子 每遍历一次 时间加1 注意不要立即将map的值变为2&#xff0c;可以通过一个缓存数组临时存放…

CentOS7使用Docker部署.net Webapi

1 准备WebApi项目 对于已存在的WebApi项目&#xff0c;需要添加Docker支持&#xff1b; 编码时&#xff0c;先设置好项目需要的端口号&#xff1a;program.cs中&#xff0c;app.Run("http://*:8000");设置端口为&#xff1a;8000在VS中&#xff0c;选中项目&#xf…

2024上半年软考报名3月18日已开启!报名流程来啦~

截止至3月15日11:00&#xff0c;河北、山东、西藏、兵团、云南、澳门、西安、陕西、辽宁、新疆、大连、青海、宁波公布了2024上半年软考报名时间。 不想一直盯着官网等报名&#xff0c;可以关注一波HCIE考证研究所&#xff0c;获得软考报名提醒哦&#xff01; 2024上半年软考…

作业:基于udp的tftp文件传输实例

#include <head.h> #include <sys/types.h> #include <sys/socket.h> #include <arpa/inet.h> #include <errno.h>#define PORT 69 //服务器绑定的端口号 #define IP "192.168.1.107" //服务器的IP地址int do_download(i…

使用JAXB生成XML的Java对象

文章目录 标题使用JAXB生成XML的Java对象根据xml生成xsd文件&#xff1a;下载trang.jar&#xff1a;使用trang.jar生成xml的xsd文件&#xff1a; 使用JAXB的xjc生成java对象&#xff1a; 标题使用JAXB生成XML的Java对象 根据xml生成xsd文件&#xff1a; 下载trang.jar&#x…

windows连接ssh/open ssh/FTP/远程打印工具

XShell工具集&#xff0c;可满足标题所列的需求&#xff0c;方便好用。 网址&#xff1a;https://www.xshell.com/zh/

如何在极狐GitLab Runner Job 添加域名host?

本文作者&#xff1a;徐晓伟 GitLab 是一个全球知名的一体化 DevOps 平台&#xff0c;很多人都通过私有化部署 GitLab 来进行源代码托管。极狐GitLab 是 GitLab 在中国的发行版&#xff0c;专门为中国程序员服务。可以一键式部署极狐GitLab。 在极狐GitLab Runner Job 添加域名…

C 引用方式调用函数

通过引用传递方式&#xff0c;形参为指向实参地址的指针&#xff0c;当对形参的指向操作时&#xff0c;就相当于对实参本身进行的操作。 传递指针可以让多个函数访问指针所引用的对象&#xff0c;而不用把对象声明为全局可访问。 /* 函数定义 */ void swap(int *x, int *y) {…

MySQL进阶45讲【34】为什么临时表可以重名?

1 前言 在上一篇文章中&#xff0c;我们在优化join查询的时候使用到了临时表。当时&#xff0c;我们是这么用的&#xff1a; create temporary table temp_t like t1; alter table temp_t add index(b); insert into temp_t select * from t2 where b>1 and b<2000; se…

为什么我学了几天 STM32 感觉一脸茫然?

为什么我学了几天 STM32 感觉一脸茫然&#xff1f; 如果你只有C语言基础就马上学习STM32&#xff0c;你一定会有这些疑惑&#xff1a; 为什么有这么多没见过的API函数&#xff1f;没见过的变量&#xff08;寄存器&#xff09;名称&#xff1f; 为什么工程除了main.c&#xff…

机器人现有力控技术检索

文章目录 力控技术1 基本柔顺力控1.1 直接力控1.2 间接力控1.2.1 被动和主动柔顺控制1.2.2 混合力位控制1.2.3 阻抗&导纳力控1.2.3.1 原理1.2.3.2 区别和联系1.2.3.3 工程应用 1.2.4 阻抗力控1.2.5 导纳力控 2 先进力控2.1 自适应力控2.2 鲁棒力控2.3 学习力控 3 智能力控3…

深度学习神经网络训练环境配置以及演示

&#x1f3ac;个人简介&#xff1a;一个全栈工程师的升级之路&#xff01; &#x1f4cb;个人专栏&#xff1a;高性能&#xff08;HPC&#xff09;开发基础教程 &#x1f380;CSDN主页 发狂的小花 &#x1f304;人生秘诀&#xff1a;学习的本质就是极致重复! 目录 1 NVIDIA Dr…

2024-3-18-C++day6作业

1>思维导图 2>试编程 要求: 封装一个动物的基类&#xff0c;类中有私有成员&#xff1a;姓名&#xff0c;颜色&#xff0c;指针成员年纪 再封装一个狗这样类&#xff0c;共有继承于动物类&#xff0c;自己拓展的私有成员有&#xff1a;指针成员&#xff1a;腿的个数&a…