198/213/337. House Robber I/II/III

  • 用两个数组(可以简化为两个数)来保存当前步偷和不偷的情况,下一步计算的时候用到前一步偷或不偷的结果。
  • 当前步不偷的最大值,是前一步偷或者不偷的最大值(前一步不偷可能比前一步偷要大)
  • 198题,动态规划
    def rob(self, nums):
        """
        :type nums: List[int]
        :rtype: int
        """
        if len(nums) == 0:
            return 0
        
        r = nums[0]
        nr = 0
        
        for money in nums[1:]:
            pre_r = r
            pre_nr = nr
            
            # 当前步要偷的话,能获得当前的钱+前一步不偷的钱
            r = pre_nr + money
            # 当前步不偷的话,能获得最大的钱是前一步偷或者不偷的最大钱数
            nr = max(pre_nr, pre_r)
            
        return max(r, nr)
  • 213题,环形的房子
    def rob(self, nums):
        """
        :type nums: List[int]
        :rtype: int
        """
        # 其实是两次动态规划的解法:
        # 1.偷第一个房子的前提下执行一遍;2.不偷第一个房子的前提下执行一遍;

        if len(nums) == 0:
            return 0
        # 初始化中多加一个len(nums)==1的情况
        if len(nums) == 1:
            return nums[0]

        # 偷第一个房子的前提下想偷当前房子
        rf_r = nums[0]
        # 偷第一个房子的前提下不偷当前房子
        # (注意初始化要为0,因为第一次偷第二个房子的时候,要用到这个数据,此时第一个房子不能偷)
        rf_nr = 0
        # 不偷第一个房子的前提下偷当前房子
        nrf_r = 0
        # 不偷第一个房子的前提下不偷当前房子
        nrf_nr = 0

        for money in nums[1:]:
            pre_rf_r = rf_r
            pre_rf_nr = rf_nr
            pre_nrf_r = nrf_r
            pre_nrf_nr = nrf_nr

            rf_r = pre_rf_nr + money
            rf_nr = max(pre_rf_r, pre_rf_nr)
            nrf_r = pre_nrf_nr + money
            nrf_nr = max(pre_nrf_r, pre_nrf_nr)

        # 返回中间两种可能
        return max(rf_nr, nrf_r)
  • 337题
    def rob(self, root):
        """
        :type root: TreeNode
        :rtype: int
        """
        res = self.helper(root)
        return max(res[0], res[1])

    def helper(self, root):
        if not root:
            return [0, 0]
        left_res = self.helper(root.left)
        right_res = self.helper(root.right)
        # 偷当前结点:当前结点的结果+左孩子不偷的结果+右孩子不偷的结果
        r = root.val + left_res[0] + right_res[0]
        # 不偷当前结点:左孩子偷或不偷的最大值+右孩子偷或不偷的最大值
        nr = max(left_res[0], left_res[1]) + max(right_res[0], right_res[1])
        res = [nr, r]
        return res
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,100评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,308评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,718评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,275评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,376评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,454评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,464评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,248评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,686评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,974评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,150评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,817评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,484评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,140评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,374评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,012评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,041评论 2 351

推荐阅读更多精彩内容

  • 今天刷 leetcode 发现了大神操作,对于刚开始刷题的我只能膜拜一下,顺便写个随笔。 题目: You are ...
    Theodore的技术站阅读 773评论 0 51
  • 213. House Robber II You are a professional robber planni...
    随时学丫阅读 165评论 0 0
  • NO.1 推荐语:每个人都想有一个动物朋友吧,不管你年少或年老 简介:2岁的法国女孩蒂皮所选择的惊险生活,完全在你...
    稻子未熟阅读 737评论 2 4
  • 今天是闰六月廿六 早上还是阳光满怀,晌午就变了天 闷雷不断,凉风习习 让人不禁觉得,仿佛提前进入了深秋 身体上的冷...
    妮诚阅读 331评论 0 0
  • 又一年盛夏,又一季离别。 火红的凤凰花在枝头绽放,明艳而热烈,那一抹令人惊叹的赤红也拉开了离别的序曲。 1 四年前...
    虚一而静心阅读 507评论 0 3