编写一个算法来判断一个数是不是“快乐数”。
一个“快乐数”定义为:对于一个正整数,每一次将该数替换为它每个位置上的数字的平方和
,然后重复这个过程直到这个数变为 1,也可能是无限循环但始终变不到 1。如果可以变为 1,那么这个数就是快乐数。
示例:
输入: 19输出: true解释:1^2 + 9^2 = 828^2 + 2^2 = 686^2 + 8^2 = 1001^2 + 0^2 + 0^2 = 1
字典 Map
来记录循环过程中各个位置上的数字的平方和/*** @param {number} n* @return {boolean}*/var isHappy = function(n) {const mapResult = new Map()let currentSum = getSum(n)while (currentSum !== 1) {const getMapResult = mapResult.get(currentSum)if (!getMapResult) {mapResult.set(currentSum, 1)} else {return false}currentSum = getSum(currentSum)}return true}/* 获取数字各个位数之和 */var getSum = function(num) {let sum = 0const numStr = String(num)for (let i = 0; i < numStr.length; i++) {sum = sum + Math.pow(numStr[i], 2)}return sum}
205、242、290、349、350、451