Skip to content

Latest commit

 

History

History
29 lines (28 loc) · 792 Bytes

File metadata and controls

29 lines (28 loc) · 792 Bytes
/*
编写一个算法来判断一个数 n 是不是快乐数。
「快乐数」定义为:
对于一个正整数,每一次将该数替换为它每个位置上的数字的平方和。
然后重复这个过程直到这个数变为 1,也可能是 无限循环 但始终变不到 1。
如果 可以变为  1,那么这个数就是快乐数。
如果 n 是快乐数就返回 true ;不是,则返回 false 。
 */
var isHappy = function(n) {
  let existedNum = {};
  let re = 0;
  let lastNum = n;
  while (re !== 1) {
    n = lastNum;
    re = 0;
    while (n >= 1) {
      let b = n % 10;
      re += b * b;
      n = (n / 10) >>> 0; //对非负整数右移取整
    }
    if (existedNum[re]) return false;
    existedNum[re] = true;
    lastNum = re;
  }
  return true;
};