算法每日一题 Day03|快慢双指针解决快乐树问题

文章目录

快乐数(附链接)

https://leetcode.cn/problems/happy-number/description/

一、题目描述

二、思路

第一种情况,当n=19时,通过重复计算这个数最终变为1,形成一个全是1的环。

第二种情况,当n=2时,通过重复计算,发现最终也会形成一个环,一个没有1的环。

所以可以定义两个指针,快指针fast一次走两步,慢指针slow一次走一步,看它们相遇的时候的数是不是1,如果是1,则这个数就为快乐数,否则这个数就不是快乐数。

三、关键点

  • 能想到用快慢双指针来解决这道题

四、代码(Java / 你常用语言)

java 复制代码
class Solution {
    public int sqrtSum(int n) {
        int sum = 0;
        while (n != 0) {
            //计算每个位数上的平方和
            int i = n % 10;
            sum += i * i;
            n = n / 10;
        }
        return sum;
    }

    public boolean isHappy(int n) {
        //让fast指针先走一步,这样才能进入后面的循环中
        int fast = sqrtSum(n);
        int slow = n;
        while (slow != fast) {
            //slow走一步,fast走两步
            slow = sqrtSum(slow);
            fast = sqrtSum(sqrtSum(fast));
        }
       
        return slow ==1 ;
    }
}

五、总结

  • 这题属于什么类型?
    这道题本质属于"数学 + 链表判环思想"的问题,可以看作是对数字进行不断变换后形成的序列问题。
相关推荐
流年如夢19 分钟前
栈和列队(LeetCode)
数据结构·算法·leetcode·链表·职场和发展
Hello.Reader1 小时前
算法基础(十)——分治思想把大问题拆成小问题
java·开发语言·算法
绛橘色的日落(。・∀・)ノ2 小时前
机器学习之评估与偏差方差分析
算法
消失的旧时光-19432 小时前
C语言对象模型系列(四)《Linux 内核里的 container_of 到底是什么黑魔法?》—— 一篇讲透 Linux 内核的“对象模型”核心技巧
linux·c语言·算法
AI_Ming3 小时前
从0开始学AI:层归一化,原来是这回事!
算法·ai编程
WL_Aurora3 小时前
备战蓝桥杯国赛【Day 8】
算法·蓝桥杯
智者知已应修善业4 小时前
【51单片机模拟生日蜡烛】2023-10-10
c++·经验分享·笔记·算法·51单片机
MediaTea4 小时前
Scikit-learn:从数据到结构——无监督学习的最小闭环
人工智能·学习·算法·机器学习·scikit-learn
智者知已应修善业4 小时前
【51单片机如何让LED灯从一亮到八,再从八亮到一】2023-10-13
c++·经验分享·笔记·算法·51单片机
qeen874 小时前
【数据结构】二叉树相关经典函数C语言实现
c语言·数据结构·c++·笔记·学习·算法·二叉树