๐ŸŒ— 337. ๆ‰“ๅฎถๅŠซ่ˆ III

ๅžไฝ›็ซฅๅญ2022ๅนด6ๆœˆ9ๆ—ฅๅฐไบŽ 1 ๅˆ†้’Ÿ

๐ŸŒ— 337. ๆ‰“ๅฎถๅŠซ่ˆ III

้šพๅบฆ: ๐ŸŒ—

้—ฎ้ข˜ๆ่ฟฐ

img_37.png


่งฃๆณ•

/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode() {}
 *     TreeNode(int val) { this.val = val; }
 *     TreeNode(int val, TreeNode left, TreeNode right) {
 *         this.val = val;
 *         this.left = left;
 *         this.right = right;
 *     }
 * }
 */
class Solution {
    public int rob(TreeNode root) {
        // ๆ€่ทฏ๏ผš
        // ไบŒๅ‰ๆ ‘็š„ๅŽๅบ้ๅŽ† + dp
        int[] res = mySol(root);
        return Math.max(res[0], res[1]);
    }

    private int[] mySol(TreeNode root) {
        int[] res = new int[] {0, 0};
        // ้€’ๅฝ’็ปˆๆญขๆกไปถ
        if(root == null) {
            return res;
        }
        
        int[] left = mySol(root.left);
        int[] right = mySol(root.right);

        // ๅ•ๅฑ‚้€’ๅฝ’้€ป่พ‘
        res[0] = Math.max(left[0], left[1]) + Math.max(right[0], right[1]);
        res[1] = left[0] + right[0] + root.val;
        return res;
    }
}

่พ“ๅ‡บ

img_36.png

ไธŠๆฌก็ผ–่พ‘ไบŽ: 2022/6/20 ไธ‹ๅˆ8:24:47
่ดก็Œฎ่€…: liuxianzhishou