算法003:快乐数

这道题采用快慢双指针的方法。

为了弄清楚这个题到底是要我们干嘛,我们把整个过程类比一下:

不管是n=19还是n=2,我们都把它当成一种判断链表是否有环的方式。

对于n=19,题干是这样解释的:

我们把它当成链表,最后判断链表是否有环;在这个题里面,也就是判断最终的结果是否为1。

为什么能够这样判断呢?

对于快乐数,一直到最后到1,我们可以看做最后进入了只有1的循环。

对于非快乐数,它们的平方和序列会进入一个固定的循环,例如4 → 16 → 37 → 58 → 89 → 145 → 42 → 20 → 4。

于是发现:只需要判断最终循环,结果是不是1就能够判断是不是快乐数。

这时候又会有另一个问题:如何知道我们判断的时候是因为 非快乐数不是1 而不是因为 快乐数还没有循环到一定的次数所以还没到1?

其实这就是为什么我们使用快慢双指针的原因了。只有已经进入了环,那么才会有慢指针追上快指针的那个时候,否则就会认为还没有进入循环,还有可能是在第一个循环中。

此时这个题的思路就明晰了,先规定两个指针,slow和fast,fast一次执行两次操作,slow一次执行一次操作,等到slow和fast相等的时候判断值是否为1。

代码就很好操作了,先把一次操作作为一个方法,只需要让fast和slow执行这个方法就行了。

(slow和fast初始化的时候不能相等,先让fast执行一次)

class Solution {
    public int bitSum(int n){
        int sum = 0;
            while(n != 0){
                int t = n % 10;
                sum += t * t;
                n = n / 10;
            }
            return sum;
        }

    public boolean isHappy(int n) {
        int slow = n;
        int fast = bitSum(n);
        while(slow != fast){
            slow = bitSum(slow);
            fast = bitSum(bitSum(fast));
        }
        return slow == 1;
    }
}

tips:把快乐数的循环当成全都是1的循环。

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

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

相关文章

如何挑选最适合你的渲染工具

随着技术的发展,云渲染平台逐渐成为设计师、动画师、影视制作人员等创意工作者的得力助手。然而,市场上的云渲染平台种类繁多,如何选择最适合自己的渲染工具成为了一个需要认真考虑的问题。 在挑选适合自己的云渲染工具时,我们需…

YOLOv10涨点改进:原创自研 | GhostNet融合 | 从廉价的操作中生成更多的特征图

文章目录 GhostNet理论基础实验部分改进方案新增yolov10s-ghost.yaml文件代码运行GhostNet理论基础 Ghost Module是一种模型压缩的方法,即在保证网络精度的同时减少网络参数和计算量,从而提升计算速度(speed),降低延时(latency)。Ghost 模块可以代替现有卷积网络中的每…

OpenAI模型规范概览

这是OpenAI对外分享的模型规范文档(Model Spec),它定义了OpenAI希望在API接口和ChatGPT(含GPT系列产品)中模型的行为方式,这也是OpenAI超级对齐团队奉行的行为准则,希望能对国内做RLHF的同学有帮…

.Net实现SCrypt Hash加密

方案1 (加密后存储“算法设置”、“盐(随机值)”、“Hash值”,以“$”分隔): //Nuget引入SCrypt.NET库 using Org.BouncyCastle.Crypto.Generators; using Scrypt; using System; using System.Security.Cryptography; namespace …

Apache OFBiz 路径遍历导致RCE漏洞复现(CVE-2024-36104)

0x01 产品简介 Apache OFBiz是一个电子商务平台,用于构建大中型企业级、跨平台、跨数据库、跨应用服务器的多层、分布式电子商务类应用系统。是美国阿帕奇(Apache)基金会的一套企业资源计划(ERP)系统。该系统提供了一整套基于Java的Web应用程序组件和工具。 0x02 漏洞概…

90后机器人创业者再获10亿元融资,为精密传动行业注入新动力!

据了解,一位90后机器人创业者再次获得近10亿元人民币的融资,这一消息在精密传动行业引起了广泛关注。 杭州宇树科技有限公司(简称“宇树”),2024年春节前完成了B2轮融资,融资近10亿元人民币,本轮…

pyqt5 tablewidget实现excel拖曳填充

代码主要涉及鼠标事件和绘图,selectionModel,selectedIndexes。 import sys from PyQt5.QtCore import QPoint, Qt, QCoreApplication, pyqtSlot from PyQt5.QtGui import QBrush, QPixmap, QColor, QPainter,QIcon,QPolygon from PyQt5.QtWidgets imp…

【Java】解决Java报错:ClassCastException

文章目录 引言1. 错误详解2. 常见的出错场景2.1 错误的类型转换2.2 泛型集合中的类型转换2.3 自定义类和接口转换 3. 解决方案3.1 使用 instanceof 检查类型3.2 使用泛型3.3 避免不必要的类型转换 4. 预防措施4.1 使用泛型和注解4.2 编写防御性代码4.3 使用注解和检查工具 5. 示…

64. UE5 RPG 创建新的双手攻击怪物

在上一篇文章中,我们实现了新的功能,现在可以创建多个普通攻击动画,并且可以根据你所使用的普通攻击动画,设置不同的攻击位置。比如,你使用武器,那么攻击位置需要从武器上获取,如果你没有持有武…

《精通ChatGPT:从入门到大师的Prompt指南》第2章:Prompt的基本概念

2.1 什么是Prompt 在了解和使用ChatGPT的过程中,理解和掌握Prompt的概念是至关重要的。Prompt可以简单地定义为一段指令或请求,它向AI模型提供了生成特定回应或行为所需的初始信息。具体而言,Prompt是用户与AI系统之间的桥梁,通过…

MatrixOne→MatrixOS:矩阵起源的创业史即将用“AI Infra”和“AI Platform”书写新章程

在数字化浪潮的推动下,MatrixOne的故事就像一部科技界的创业史诗,它始于一个简单而宏伟的梦想——构建一个能够支撑起新一代数字世界的操作系统。想象一下,在AIGC时代,数据流动如同“血液”,算法运转如同“心跳”&…

【Neo4j】Windows11使用Neo4j导入CSV数据可视化知识图谱

Windows11使用Neo4j导入CSV数据可视化知识图谱 序1. 安装JDK21(1)下载(2)安装(3)环境配置 2. 安装Neo4j(1)下载(2)解压安装(3)环境配置…

国货美妆品牌站上C位,抖音618大促期间相关产品销量同比增长53%

每年618大促时期是各类美妆产品销售旺季。近两年,爱美人士的囤货清单里出现越来越多国货美妆品牌。 据《2023年中国化妆品年鉴》,去年国内美妆市场总体规模达7972亿元,其中,国货市场份额达到50.4%,首次超越外资品牌。…

Cloudpods 强大的多云管理平台部署

简介 Cloudpods 是一款简单、可靠的企业IaaS资源管理软件。帮助未云化企业全面云化IDC物理资源,提升企业IT管理效率。 Cloudpods 帮助客户在一个地方管理所有云计算资源。统一管理异构IT基础设施资源,极大简化多云架构复杂度和难度,帮助企业…

遗址博物馆ar互动展示软件提供丰富的趣味化体验

在自然博物馆的每一个角落,都隐藏着大自然的奥秘与魅力。为了让每一位参观者都能深入体验、探索这些奥秘,我们引入了前沿的AR技术,为您带来一场前所未有的沉浸式自然之旅。 步入博物馆,您手中的AR相机将成为您的更佳向导。自然博物…

「动态规划」如何求最小路径和?

64. 最小路径和https://leetcode.cn/problems/minimum-path-sum/description/ 给定一个包含非负整数的m x n网格grid,请找出一条从左上角到右下角的路径,使得路径上的数字总和为最小。说明:每次只能向下或者向右移动一步。 输入:…

短视频矩阵源码----如何做正规开发规则分享:

一、什么是SaaS化服务技术开发? (短视频矩阵系统是源头开发的应该分为3个端口---- 总后台控制端、总代理端口,总商户后台) SaaS是软件即服务(Software as a Service)的缩写。它是一种通过互联网提供软件应…

jvm学习笔记(二) ----- 垃圾回收

GC 一、判定对象是否是垃圾1.引用计数法2.可达性分析算法 二、垃圾回收算法1.标记清除2.标记整理3. 复制4. 分代垃圾回收1.尝试在伊甸园分配2.大对象直接晋升至老年代3.多次存活的对象4.老年代连续空间不足,触发 Full GC 链接: jvm学习笔记(一) ----- JAVA 内存 链接…

Android存储空间不足?试试这8个快速解决方案!

在当今的科技时代,Android智能手机已成为我们日常生活的重要组成部分,因为它们保存着我们大量的关键数据。然而,随着我们的使用模式不断扩大,手机内部存储的可用性经常变得有限。手机存储空间不足不仅会损害设备的功能和响应能力&…

代码随想录第27天|贪心算法part1

455.分发饼干 先给孩子和饼干排序&#xff0c;每次选取一个最大的饼干给一个最大胃口的孩子&#xff0c;直到饼干分完或者遍历完孩子 class Solution { public:int findContentChildren(vector<int>& g, vector<int>& s) {sort(g.begin(), g.end());sort(…