乐趣区

关于leetcode:Leetcode-PHP题解D128-202-Happy-Number

D128 202. Happy Number

题目链接

202. Happy Number

题目剖析

这道题目不简单,就是给定一个数字,把每一位拆开来算个平方再相加。始终加到和为 1 就是高兴数字 Happy Number 返回 true,或者失去循环就返回 false。

解题思路

我感觉这个题目的“难点”在于怎么晓得循环了。比较简单的方法是把求过的和都记录进一个数组外面,每次求完一次和就判断一下是否呈现过,即可知是否循环。这种计划的毛病就是每算一次要遍历一遍数组了。

我想另辟蹊径换种办法。

我先通过剖析 100 以内的数字种,有哪些数字是符合要求的。通过计算发现:和为 100 时,只可能从 68 或 86 而得来。而这两个数字又是从 28 或 82 得来的。再往前就是 19 和 91 了。而这两个数字是不可能通过 100 以内的数字每一位拆开求平方和得来。咱们能够画出 19/91=>28/82=>68/86=>100 这样的链条来。
同理、还有另外两个链条:
7/70=>49/94=>79/97=>130=>10

44=>23/32=>13/31=>10

在链条里呈现的数字都能保障最初失去的是 1。因而咱们把这些数字保存起来用来对照。一旦在计算过程中,呈现了这个数字,那就阐明这个数肯定是高兴数字了。

最终代码

<?php
class Solution {

    /**
     * @param Integer $n
     * @return Boolean
     */
    function isHappy($n) {$safe = [1,7,10,13,19,23,28,31,28,31,32,44,49,68,70,79,82,86,91,94,97,100];
        $total = $n;
        do{$digits = str_split($total);
            $total = array_reduce($digits, function($val, $s){
                $val += $s*$s;
                return $val;
            }, 0);
        }while($total>100);
        if(in_array($total, $safe)){return true;}
        return false;
    }
}

若感觉本文章对你有用,欢送用爱发电赞助。

退出移动版