代码随想三刷动态规划篇7

代码随想三刷动态规划篇7

  • [198. 打家劫舍](#198. 打家劫舍)
  • [213. 打家劫舍 II](#213. 打家劫舍 II)
  • [337. 打家劫舍 III](#337. 打家劫舍 III)
  • [121. 买卖股票的最佳时机](#121. 买卖股票的最佳时机)

198. 打家劫舍

题目

链接

代码

java 复制代码
class Solution {
    public int rob(int[] nums) {
        if(nums.length==1){
            return nums[0];
        }
        if(nums.length==2){
            return Math.max(nums[0],nums[1]);
        }
        
        int[] dp = new int[nums.length];
        dp[0] = nums[0];
        dp[1] = Math.max(nums[0],nums[1]);
        for(int i=2;i<nums.length;i++){
            dp[i]= Math.max(dp[i-1],dp[i-2]+nums[i]);
        }
        return dp[nums.length-1];
    }
}

213. 打家劫舍 II

题目

链接

代码

java 复制代码
class Solution {
    public int rob(int[] nums) {
        if(nums.length==1){
            return nums[0];
        }
        if(nums.length==2){
            return Math.max(nums[0],nums[1]);
        }
        int[] dpLeft = new int[nums.length];//不偷最后一个
        int[] dpRight = new int[nums.length];//不偷第一个
        dpLeft[0] = nums[0];
        dpLeft[1] = Math.max(nums[0],nums[1]);

        dpRight[1] = nums[1];
        if(nums.length>=3){
            dpRight[2] = Math.max(nums[1],nums[2]);
        }
        for(int i =2;i<nums.length-1;i++){//不偷最后一个
            dpLeft[i] = Math.max(dpLeft[i-1],dpLeft[i-2]+nums[i]);
        }
        for(int i =3;i<nums.length;i++){//不偷前一个
            dpRight[i] = Math.max(dpRight[i-1],dpRight[i-2]+nums[i]);
        }
        return Math.max(dpLeft[nums.length-2],dpRight[nums.length-1]);
    }
}

337. 打家劫舍 III

题目

链接

代码

java 复制代码
/**
 * 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 {
    Map<TreeNode,Integer> map = new HashMap();
    public int rob(TreeNode root) {
        if(root==null){
            return 0;
        }
        if(map.containsKey(root)){
            return map.get(root);
        }
        int money = root.val;
        if(root.left!=null){
            money+=rob(root.left.left)+rob(root.left.right);
        }
        if(root.right!=null){
            money+=rob(root.right.left)+rob(root.right.right);
        }
        int res = Math.max(money,rob(root.left)+rob(root.right));
        map.put(root,res);
        return res;
    }
}

121. 买卖股票的最佳时机

题目

链接

代码

java 复制代码
class Solution {
    public int maxProfit(int[] prices) {
        int[][] dp = new int[prices.length][2];
        dp[0][0] = 0;
        dp[0][1] = -prices[0];
        for(int i = 1;i<prices.length;i++){
            dp[i][0] = Math.max(dp[i-1][0],dp[i-1][1]+prices[i]);
            dp[i][1] = Math.max(dp[i-1][1],-prices[i]);
        }
        return dp[prices.length-1][0];
    }
}
相关推荐
星火开发设计28 分钟前
C++ 输入输出流:cin 与 cout 的基础用法
java·开发语言·c++·学习·算法·编程·知识
We་ct39 分钟前
LeetCode 289. 生命游戏:题解+优化,从基础到原地最优
前端·算法·leetcode·矩阵·typescript
自己的九又四分之三站台40 分钟前
9:MemNet记忆层使用,实现大模型对话上下文记忆
人工智能·算法·机器学习
LXS_3571 小时前
STL - 函数对象
开发语言·c++·算法
aini_lovee1 小时前
基于粒子群算法(PSO)优化BP神经网络权值与阈值的实现
神经网络·算法
老鼠只爱大米1 小时前
LeetCode经典算法面试题 #230:二叉搜索树中第K小的元素(递归法、迭代法、Morris等多种实现方案详细解析)
算法·leetcode·二叉搜索树·二叉树遍历·第k小的元素·morris遍历
星期五不见面1 小时前
嵌入式学习!(一)C++学习-leetcode(21)-26/1/29
学习·算法·leetcode
2501_941322031 小时前
通信设备零部件识别与检测基于改进YOLOv8-HAFB-2算法实现
算法·yolo
modelmd1 小时前
【递归算法】汉诺塔
python·算法
2401_838472512 小时前
C++中的装饰器模式实战
开发语言·c++·算法