Happy Number

題目來源
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

判斷一個整數(shù)是不是快樂的…最直接的方法就是直接算…用了一個哈希表來存儲已經(jīng)出現(xiàn)過的见坑,假如出現(xiàn)循環(huán)節(jié)了的話那肯定就不是快樂數(shù)了婆硬!

class Solution {
public:
    bool isHappy(int n) {
        unordered_map<int, int> map;
        while (n != 1 && !map[n]) {
            map[n]++;
            int newN = 0;
            while (n > 0) {
                newN += (n % 10) * (n % 10);
                n /= 10;
            }
            n = newN;
        }
        if (n == 1)
            return true;
        else
            return false;
    }
};

我們用了O(n)的空間,然后又有大神出現(xiàn)了暂雹,大吼一聲說策治,渣渣脓魏,F(xiàn)loyd你都忘了嗎?要你何用通惫!咔嚓茂翔,把我干掉了!
實際上也挺簡單的履腋,就是設(shè)置一個快指針一個慢指針珊燎,然后假如有環(huán)的話,快指針會追上慢指針遵湖,假如沒環(huán)的話悔政,就到尾巴了,這道題目中的尾巴就是1延旧。

class Solution {
public:
    bool isHappy(int n) {
        int fast = n, slow = n;
        do {
            slow = digitSqualSum(slow);
            fast = digitSqualSum(fast);
            fast = digitSqualSum(fast);
        } while (fast != slow && fast != 1);
        if (fast == 1)
            return true;
        else
            return false;
    }
    
    int digitSqualSum(int n)
    {
        int newN = 0;
        while (n > 0) {
            newN += (n % 10) * (n % 10);
            n /= 10;
        }
        return newN;
    }
};
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末谋国,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子迁沫,更是在濱河造成了極大的恐慌芦瘾,老刑警劉巖捌蚊,帶你破解...
    沈念sama閱讀 211,042評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異近弟,居然都是意外死亡缅糟,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,996評論 2 384
  • 文/潘曉璐 我一進店門藐吮,熙熙樓的掌柜王于貴愁眉苦臉地迎上來溺拱,“玉大人,你說我怎么就攤上這事谣辞∑人ぃ” “怎么了?”我有些...
    開封第一講書人閱讀 156,674評論 0 345
  • 文/不壞的土叔 我叫張陵泥从,是天一觀的道長句占。 經(jīng)常有香客問我,道長躯嫉,這世上最難降的妖魔是什么纱烘? 我笑而不...
    開封第一講書人閱讀 56,340評論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮祈餐,結(jié)果婚禮上擂啥,老公的妹妹穿的比我還像新娘。我一直安慰自己帆阳,他們只是感情好哺壶,可當(dāng)我...
    茶點故事閱讀 65,404評論 5 384
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著蜒谤,像睡著了一般山宾。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上鳍徽,一...
    開封第一講書人閱讀 49,749評論 1 289
  • 那天资锰,我揣著相機與錄音,去河邊找鬼阶祭。 笑死绷杜,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的濒募。 我是一名探鬼主播鞭盟,決...
    沈念sama閱讀 38,902評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼萨咳!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起疫稿,我...
    開封第一講書人閱讀 37,662評論 0 266
  • 序言:老撾萬榮一對情侶失蹤培他,失蹤者是張志新(化名)和其女友劉穎鹃两,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體舀凛,經(jīng)...
    沈念sama閱讀 44,110評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡俊扳,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,451評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了猛遍。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片馋记。...
    茶點故事閱讀 38,577評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖懊烤,靈堂內(nèi)的尸體忽然破棺而出梯醒,到底是詐尸還是另有隱情,我是刑警寧澤腌紧,帶...
    沈念sama閱讀 34,258評論 4 328
  • 正文 年R本政府宣布茸习,位于F島的核電站,受9級特大地震影響壁肋,放射性物質(zhì)發(fā)生泄漏号胚。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,848評論 3 312
  • 文/蒙蒙 一浸遗、第九天 我趴在偏房一處隱蔽的房頂上張望猫胁。 院中可真熱鬧,春花似錦跛锌、人聲如沸弃秆。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,726評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽驾茴。三九已至,卻和暖如春氢卡,著一層夾襖步出監(jiān)牢的瞬間锈至,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,952評論 1 264
  • 我被黑心中介騙來泰國打工译秦, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留峡捡,地道東北人。 一個月前我還...
    沈念sama閱讀 46,271評論 2 360
  • 正文 我出身青樓筑悴,卻偏偏與公主長得像们拙,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子阁吝,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,452評論 2 348

推薦閱讀更多精彩內(nèi)容

  • **2014真題Directions:Read the following text. Choose the be...
    又是夜半驚坐起閱讀 9,429評論 0 23
  • 背景 一年多以前我在知乎上答了有關(guān)LeetCode的問題, 分享了一些自己做題目的經(jīng)驗砚婆。 張土汪:刷leetcod...
    土汪閱讀 12,737評論 0 33
  • 別閑著啦, 趕緊買房結(jié)婚埂奈, 不然要交 “單身稅”啦迄损! 1 這一周我和閨蜜、女性朋友們聊的最多的話題就是: 看了產(chǎn)婦...
    蛻變的痛閱讀 263評論 0 1
  • 今日帶媽去協(xié)和看病账磺,掛了骨科錢文偉副教授的號芹敌,民航醫(yī)院診斷是類風(fēng)濕性關(guān)節(jié)炎,好不容易輪到我們進去垮抗,我媽主動描述病情...
    一世驚鴻閱讀 98評論 0 0
  • 我不知道鳥往哪里飛氏捞, 也不知道風(fēng)往哪里追, 這樣的夜晚太美又太黑借宵, 卻只是徒增傷悲幌衣。
    梅麗得斯閱讀 163評論 0 1