算法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执行一次)

java 复制代码
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的循环。

相关推荐
程序员东岸8 小时前
《数据结构——排序(中)》选择与交换的艺术:从直接选择到堆排序的性能跃迁
数据结构·笔记·算法·leetcode·排序算法
程序员-King.8 小时前
day104—对向双指针—接雨水(LeetCode-42)
算法·贪心算法
神仙别闹9 小时前
基于C++实现(控制台)应用递推法完成经典型算法的应用
开发语言·c++·算法
Ayanami_Reii9 小时前
进阶数据结构应用-一个简单的整数问题2(线段树解法)
数据结构·算法·线段树·延迟标记
listhi5209 小时前
基于改进SET的时频分析MATLAB实现
开发语言·算法·matlab
Keep_Trying_Go10 小时前
基于Zero-Shot的目标计数算法详解(Open-world Text-specified Object Counting)
人工智能·pytorch·python·算法·多模态·目标统计
xl.liu10 小时前
零售行业仓库商品数据标记
算法·零售
confiself10 小时前
通义灵码分析ms-swift框架中CHORD算法实现
开发语言·算法·swift
做怪小疯子10 小时前
LeetCode 热题 100——二叉树——二叉树的层序遍历&将有序数组转换为二叉搜索树
算法·leetcode·职场和发展
CoderYanger11 小时前
递归、搜索与回溯-记忆化搜索:38.最长递增子序列
java·算法·leetcode·1024程序员节