Leetcode刷题 202.快乐数

很多前端的同学对数据结构和算法这块没有太多的概念,很多leetcode的题目看不懂,有时候可能看了题解也不知道是什么意思。上一篇我们对链表的数据结构有了了解,下面根据题目来练习一下

202. 快乐数

题目

编写一个算法来判断一个数 n 是不是快乐数。

「快乐数」 定义为:

  • 对于一个正整数,每一次将该数替换为它每个位置上的数字的平方和。
  • 然后重复这个过程直到这个数变为 1,也可能是 无限循环 但始终变不到 1。
  • 如果这个过程 结果为 1,那么这个数就是快乐数。

如果 n快乐数 就返回 true ;不是,则返回 false

题解

这道题我们可以转换为判断一个链表是否有环

比如:

  1. 如果遍历某个节点为1,说明链表没环,就是快乐数
  2. 如果遍历到重复的节点值,说明有环,就不是快乐数

我们用两张图来表示: 没环,是快乐数的图:

有环,不是快乐数的图: 下面我们来实现下代码:

js 复制代码
var isHappy = function (n) {
  let pre = n, cur = getNext(n)

  while (pre !== cur && cur !== 1) {
    pre = getNext(pre)
    cur = getNext(getNext(cur))
  }

  return cur === 1
}

首先我们需要定义两个快慢指针。pre表示慢指针,每次只走一步。cur表示快指针,每次走两步。这里我们提前让快指针先走一步。getNext表示向后走一步的方法。

我们的循环条件是要满足两个条件:

  1. 快慢指针不能相当,如果相等则说明有环,那么就不是快乐数(也就是为什么上面让快指针先走一步)
  2. 快指针不能为1,如果为1则说明是快乐数 最后返回的时候,只需要判断cur是否为1就可以了,如果为1,则说明是快乐数。如果不为1,则快慢指针相等的时候退出的循环,则说明是有环的,那就不是快乐数。

那么我们来看下getNext是怎么实现的。

js 复制代码
var getNext = function (n) {
  let t = 0
  while (n) {
    t += (n % 10) * (n % 10)
    n = Math.floor(n / 10)
  }
  return t
}

那n = 19来举例说明。

t += (n % 10) * (n % 10), (n % 10)。通过n % 10可以找到个位数的值,也就是9,那么t就是 9 * 9,然后通过n = Math.floor(n / 10)来把个位数去掉,19/10为1.9, Math.floor(1.9)为1, n就为1,进入下一次循环,每次循环的结果t叠加,就可以得到我们希望的值。

完整代码:

js 复制代码
var isHappy = function (n) {
  let pre = n, cur = getNext(n)

  while (pre !== cur && cur !== 1) {
    pre = getNext(pre)
    cur = getNext(getNext(cur))
  }

  return cur === 1
}



var getNext = function (n) {
  let t = 0
  while (n) {
    t += (n % 10) * (n % 10)
    n = Math.floor(n / 10)
  }

  return t
}

欢迎大家点赞评论,大家一起学习一起进步!!!

相关推荐
莹雨潇潇1 分钟前
Docker 快速入门(Ubuntu版)
java·前端·docker·容器
Jiaberrr10 分钟前
Element UI教程:如何将Radio单选框的圆框改为方框
前端·javascript·vue.js·ui·elementui
我是哈哈hh42 分钟前
专题十_穷举vs暴搜vs深搜vs回溯vs剪枝_二叉树的深度优先搜索_算法专题详细总结
服务器·数据结构·c++·算法·机器学习·深度优先·剪枝
Tiffany_Ho1 小时前
【TypeScript】知识点梳理(三)
前端·typescript
Tisfy1 小时前
LeetCode 2187.完成旅途的最少时间:二分查找
算法·leetcode·二分查找·题解·二分
Mephisto.java1 小时前
【力扣 | SQL题 | 每日四题】力扣2082, 2084, 2072, 2112, 180
sql·算法·leetcode
robin_suli1 小时前
滑动窗口->dd爱框框
算法
丶Darling.1 小时前
LeetCode Hot100 | Day1 | 二叉树:二叉树的直径
数据结构·c++·学习·算法·leetcode·二叉树
labuladuo5202 小时前
Codeforces Round 977 (Div. 2) C2 Adjust The Presentation (Hard Version)(思维,set)
数据结构·c++·算法
安冬的码畜日常2 小时前
【D3.js in Action 3 精译_029】3.5 给 D3 条形图加注图表标签(上)
开发语言·前端·javascript·信息可视化·数据可视化·d3.js