成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

Happy Number

Thanatos / 360人閱讀

摘要:今天在上刷題的時候遇到了一個有趣的問題,問題描述如下題目大意題目大概意思是說將一個數(shù)按照個十百千位來分解如果有的話,然后求他們的平方的和,得到結(jié)果后重復(fù)這個過程。

今天在LeetCode上刷題的時候遇到了一個有趣的問題,問題描述如下:

Write an algorithm to determine if a number is “happy”.
A happy number is a number defined by the following process: Starting with any positive integer, replace the number by the sum of the squares of its digits, and repeat the process until the number equals 1 (where it will stay), or it loops endlessly in a cycle which does not include 1. Those numbers for which this process ends in 1 are happy numbers.
Example: 19 is a happy number
1^2 + 9^2 = 82
8^2 + 2^2 = 68
6^2 + 8^2 = 100
1^2 + 0^2 + 0^2 = 1
Happy Number 題目大意

題目大概意思是說將一個數(shù)按照 個、十、百、千位來分解(如果有的話),然后求他們的平方的和,得到結(jié)果后重復(fù)這個過程。最后結(jié)果為1,則該數(shù)字為happ number,則返回true,否則返回false

題目分析

第一眼看到題目其實是有點懵逼的,咋一看不知道循環(huán)結(jié)束的條件。其實循環(huán)結(jié)束的條件在題目中已經(jīng)指出來——不為happly number的時候這個循環(huán)是重復(fù)的,所以說在這個循環(huán)的過程當中,推算出來的式子是有重復(fù)的部分,下面給出數(shù)字為6的時候式子的變換過程:

0^2 + 6^2 = 36
3^2 + 6^2 = 45
4^2 + 5^2 = 41
4^2 + 1^2 = 17
1^2 + 7^2 = 50
5^2 + 0^2 = 25
2^2 + 5^2 = 29
2^2 + 9^2 = 85
8^2 + 5^2 = 89    (循環(huán)起始部分
8^2 + 9^2 = 145
1^2 + 4^2 + 5^2 = 42
4^2 + 2^2 = 20
2^2 + 0^2 = 4
4^2 + 0^2 = 16
1^2 + 6^2 = 37
3^2 + 7^2 = 58    (一輪循環(huán)結(jié)束
5^2 + 8^2 = 89    (循環(huán)重新開始

可以看到當不為happy number的時候,式子在推算到一定程度,就會開始死循環(huán),根據(jù)這個特點,這里我使用集合的特性來存儲式子,通過判斷式子是否重復(fù)來界定是否為happy number

AC代碼
/**
 * @param {number} n
 * @return {boolean}
 */
var isHappy = function (n) {
    let result = String(n).split(""),counter = 1
    let collections = new Set()
    collections.add(result.join(""))
    while (counter === collections.size) {
        result = result.reduce((total, currentValue) => {
            return total + Math.pow(currentValue, 2)
        }, 0)
        counter++
        collections.add(String(result))
        result = String(result).split("")
        if(result[0] === "1" && result.length === 1){
            return true
        }
    }
    return false
}
其他解法

在LeetCode上我發(fā)現(xiàn)我的思路還是具有普遍性,但是網(wǎng)站上我看到了兩種比較有意思的解法,下面是具體的代碼:

解法1: Using fact all numbers in [2, 6] are not happy (and all not happy numbers end on a cycle that hits this interval):

(大意就是說利用非happy number在[2,6]這個區(qū)間的特性來判斷是否為happy number

bool isHappy(int n) {
    while(n>6){
        int next = 0;
        while(n){next+=(n%10)*(n%10); n/=10;}
        n = next;
    }
    return n==1;
}

解法2:I see the majority of those posts use hashset to record values. Actually, we can simply adapt the Floyd Cycle detection algorithm. I believe that many people have seen this in the Linked List Cycle detection problem. The following is my code:

(大意是說利用修改 Floyd Cycle 來判斷是否為happy number

int digitSquareSum(int n) {
    int sum = 0, tmp;
    while (n) {
        tmp = n % 10;
        sum += tmp * tmp;
        n /= 10;
    }
    return sum;
}
bool isHappy(int n) {
    int slow, fast;
    slow = fast = n;
    do {
        slow = digitSquareSum(slow);
        fast = digitSquareSum(fast);
        fast = digitSquareSum(fast);
    } while(slow != fast);
    if (slow == 1) return 1;
    else return 0;
}

掃描下方的二維碼或搜索「tony老師的前端補習班」關(guān)注我的微信公眾號,那么就可以第一時間收到我的最新文章。

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/88454.html

相關(guān)文章

  • [Leetcode] Happy Number 快樂數(shù)

    摘要:集合法復(fù)雜度時間待定空間待定思路根據(jù)快樂數(shù)的計算方法,我們很難在有限步驟內(nèi)確定一個數(shù)是否是快樂數(shù),但使用排除法的話,我們可以嘗試確定一個數(shù)不是快樂數(shù)。根據(jù)題意,當計算出現(xiàn)無限循環(huán)的時候就不是快樂數(shù)。 Happy Number Write an algorithm to determine if a number is happy. A happy number is a number...

    lindroid 評論0 收藏0
  • [LeetCode/LintCode] Happy Number

    Problem Write an algorithm to determine if a number is happy.A happy number is a number defined by the following process: Starting with any positive integer, replace the number by the sum of the squar...

    崔曉明 評論0 收藏0
  • 紅皮書(4):引用類型

    摘要:類型類型重排序方法升序降序方法返回從參數(shù)指定位置開始到當前數(shù)組末尾的所有項。要注意的是,傳遞給構(gòu)造函數(shù)的兩個參數(shù)都是字符串不能把正則表達式字面量傳遞給構(gòu)造函數(shù)。由于構(gòu)造函數(shù)的模式參數(shù)是字符串,所以在某些情況下要對字符串進行雙重轉(zhuǎn)義。 Object類型 Array類型 重排序方法: compare 升序: function compare(value1, value2){ ...

    CoorChice 評論0 收藏0
  • 《JavaScript高級程序設(shè)計》筆記:引用類型(五)

    摘要:元素是通過指定的分隔符進行分隔的。返回值如果從中刪除了元素,則返回的是含有被刪除的元素的數(shù)組。根據(jù)使用的方法不同,這個函數(shù)執(zhí)行后的返回值可能會也可能不會影響訪問的返回值。對數(shù)組中的每一項運行給定函數(shù),返回該函數(shù)會返回的項組成的數(shù)組。 Object類型 創(chuàng)建object實例方法有兩種。第一種方法使用new操作符后跟object構(gòu)造函數(shù)。如下: var person=new Object(...

    maybe_009 評論0 收藏0

發(fā)表評論

0條評論

Thanatos

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<