算法训练营第三十六天(8.26)| 动态规划Part07:完全背包

目录

[Leecode 198.打家劫舍](#Leecode 198.打家劫舍)

[Leecode 213.打家劫舍 II](#Leecode 213.打家劫舍 II)

[Leecode 337.打家劫舍III](#Leecode 337.打家劫舍III)


Leecode 198.打家劫舍

题目地址:力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台

题目类型:打家劫舍

cpp 复制代码
class Solution {
public:
    int rob(vector<int>& nums) {
        int n = nums.size();
        if (n == 1) return nums[0];
        if (n == 2) return max(nums[0], nums[1]);
        // dp[i]代表前i家所能打劫到的最大数目
        vector<int> dp(n, 0);
        dp[0] = nums[0];
        dp[1] = max(nums[0], nums[1]);
        // dp[i] = max(dp[i - 1], dp[i - 2] + nums[i])
        for (int i = 2; i < n; ++i) {
            dp[i] = max(dp[i - 1], dp[i - 2] + nums[i]);
        }
        return dp[n - 1];
    }
};

Leecode 213.打家劫舍 II

题目地址:力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台

题目类型:打家劫舍

思路:与普通打家劫舍的区别是,首尾不能同时取,所以

cpp 复制代码
class Solution {
private:
    int rob1(vector<int>& nums) {
        int n = nums.size();
        if (n == 1) return nums[0];
        if (n == 2) return max(nums[0], nums[1]);
        // dp[i]代表前i家所能打劫到的最大数目
        vector<int> dp(n, 0);
        dp[0] = nums[0];
        dp[1] = max(nums[0], nums[1]);
        // dp[i] = max(dp[i - 1], dp[i - 2] + nums[i])
        for (int i = 2; i < n; ++i) {
            dp[i] = max(dp[i - 1], dp[i - 2] + nums[i]);
        }
        return dp[n - 1];
    }
public:
    int rob(vector<int>& nums) {
        if (nums.size() == 1) return nums[0];
        vector nums1(nums.begin(), nums.end() - 1);
        vector nums2(nums.begin() + 1, nums.end());
        return max(rob1(nums1), rob1(nums2));
    }
};

Leecode 337.打家劫舍III

题目地址:力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台

题目类型:打家劫舍

cpp 复制代码
class Solution {
private:
    // 返回的数组即为dp数组,一共连个元素:[偷当前节点获得的最大收益,不偷当前节点获得的最大收益]
    vector<int> robTree(TreeNode* root) {
        if (!root) return {0, 0};
        vector nums1 = robTree(root->left);
        vector nums2 = robTree(root->right);
        // 不取当前节点
        int val1 = max(nums1[0], nums1[1]) + max(nums2[0], nums2[1]);
        // 取当前节点
        int val2 = root->val + nums1[0] + nums2[0];
        return {val1, val2};
    } 
public:
    int rob(TreeNode* root) {
        vector<int> nums = robTree(root);
        return max(nums[0], nums[1]);
    }
};
相关推荐
旺仔老馒头.1 小时前
【数据结构与算法】手撕排序算法(二)
c语言·数据结构·算法·排序算法
好学且牛逼的马1 小时前
【Hot100 | 2 LeetCode49 字母异位词分组问题】
算法
2301_795167201 小时前
Rust 在内存安全方面的设计方案的核心思想是“共享不可变,可变不共享”
算法·安全·rust
czhc11400756632 小时前
Java117 最长公共前缀
java·数据结构·算法
java 乐山2 小时前
蓝牙网关(备份)
linux·网络·算法
云泽8082 小时前
快速排序算法详解:hoare、挖坑法、lomuto前后指针与非递归实现
算法·排序算法
数字化脑洞实验室2 小时前
智能决策算法的核心原理是什么?
人工智能·算法·机器学习
流烟默2 小时前
机器学习中拟合、欠拟合、过拟合是什么
人工智能·算法·机器学习
Brianna Home2 小时前
现代C++:从性能泥潭到AI基石
开发语言·c++·算法
再卷也是菜2 小时前
算法基础篇(10)递归型枚举与回溯剪枝
算法·深度优先·剪枝