337. House Robber III

The thief has found himself a new place for his thievery again. There is only one entrance to this area, called the "root." Besides the root, each house has one and only one parent house. After a tour, the smart thief realized that "all houses in this place forms a binary tree". It will automatically contact the police if two directly-linked houses were broken into on the same night.
Determine the maximum amount of money the thief can rob tonight without alerting the police.
Example 1:

     3
    / \
   2   3
    \   \ 
     3   1

Maximum amount of money the thief can rob = 3 + 3 + 1 = 7.
Example 2:

     3
    / \
   4   5
  / \   \ 
 1   3   1

Maximum amount of money the thief can rob = 4 + 5 = 9.

Solution:[DP思想] 遞歸 Post-order 分治 Bottom-up向上傳遞

思路:
DP思路和 198. House Robber 思路一樣
實(shí)現(xiàn):分治左右樹在跳,分別得到左/右子樹 的 含cur_max/不含prev_max 相鄰結(jié)點(diǎn)的 最大值符隙,在當(dāng)前結(jié)點(diǎn)Conquer計(jì)算出新的含本結(jié)點(diǎn)cur_max(上一層不能有相鄰的,只能用left/right.prev)和prev_max(沒相鄰orNot限制,選前面最大的就行)
Time Complexity: O(N) Space Complexity: O(1)

Solution Code:

class Solution {
    class Result {  
        int cur_max;
        int prev_max;
        Result(int cur_max, int prev_max) {
            this.cur_max = cur_max;
            this.prev_max = prev_max;
        }
    }
    
    public int rob(TreeNode root) {
        Result result = dfsHelper(root);
        return Math.max(result.cur_max, result.prev_max);
    }
    
    private Result dfsHelper(TreeNode node) {
        if(node == null) return new Result(0, 0);
        Result left = dfsHelper(node.left);
        Result right = dfsHelper(node.right);
    
        // consider this one
        int cur_max = left.prev_max + right.prev_max + node.val; 
        // if including negative case
        // int cur_max = Math.max(left.prev_max + right.prev_max, Math.max(left.prev_max, right.prev_max)) + node.val;  
                       
        // don't consider this one
        int prev_max = Math.max(left.cur_max, left.prev_max) + Math.max(right.cur_max, right.prev_max); 
        
        Result result = new Result(cur_max, prev_max);
        return result;
    }
}

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末抵怎,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子球化,更是在濱河造成了極大的恐慌齐鲤,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,194評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件饱亿,死亡現(xiàn)場(chǎng)離奇詭異蚜退,居然都是意外死亡闰靴,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,058評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門钻注,熙熙樓的掌柜王于貴愁眉苦臉地迎上來蚂且,“玉大人,你說我怎么就攤上這事幅恋⌒铀溃” “怎么了?”我有些...
    開封第一講書人閱讀 156,780評(píng)論 0 346
  • 文/不壞的土叔 我叫張陵捆交,是天一觀的道長(zhǎng)淑翼。 經(jīng)常有香客問我,道長(zhǎng)零渐,這世上最難降的妖魔是什么窒舟? 我笑而不...
    開封第一講書人閱讀 56,388評(píng)論 1 283
  • 正文 為了忘掉前任系忙,我火速辦了婚禮诵盼,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘银还。我一直安慰自己风宁,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,430評(píng)論 5 384
  • 文/花漫 我一把揭開白布蛹疯。 她就那樣靜靜地躺著戒财,像睡著了一般。 火紅的嫁衣襯著肌膚如雪捺弦。 梳的紋絲不亂的頭發(fā)上饮寞,一...
    開封第一講書人閱讀 49,764評(píng)論 1 290
  • 那天,我揣著相機(jī)與錄音列吼,去河邊找鬼幽崩。 笑死,一個(gè)胖子當(dāng)著我的面吹牛寞钥,可吹牛的內(nèi)容都是我干的慌申。 我是一名探鬼主播,決...
    沈念sama閱讀 38,907評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼理郑,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼蹄溉!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起您炉,我...
    開封第一講書人閱讀 37,679評(píng)論 0 266
  • 序言:老撾萬榮一對(duì)情侶失蹤柒爵,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后赚爵,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體棉胀,經(jīng)...
    沈念sama閱讀 44,122評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡宴霸,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,459評(píng)論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了膏蚓。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片瓢谢。...
    茶點(diǎn)故事閱讀 38,605評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖驮瞧,靈堂內(nèi)的尸體忽然破棺而出氓扛,到底是詐尸還是另有隱情,我是刑警寧澤论笔,帶...
    沈念sama閱讀 34,270評(píng)論 4 329
  • 正文 年R本政府宣布采郎,位于F島的核電站,受9級(jí)特大地震影響狂魔,放射性物質(zhì)發(fā)生泄漏蒜埋。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,867評(píng)論 3 312
  • 文/蒙蒙 一最楷、第九天 我趴在偏房一處隱蔽的房頂上張望整份。 院中可真熱鬧,春花似錦籽孙、人聲如沸烈评。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,734評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽讲冠。三九已至,卻和暖如春适瓦,著一層夾襖步出監(jiān)牢的瞬間竿开,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,961評(píng)論 1 265
  • 我被黑心中介騙來泰國(guó)打工玻熙, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留否彩,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,297評(píng)論 2 360
  • 正文 我出身青樓揭芍,卻偏偏與公主長(zhǎng)得像胳搞,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子称杨,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,472評(píng)論 2 348

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