leetcode做题笔记198. 打家劫舍

你是一个专业的小偷,计划偷窃沿街的房屋。每间房内都藏有一定的现金,影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统,如果两间相邻的房屋在同一晚上被小偷闯入,系统会自动报警

给定一个代表每个房屋存放金额的非负整数数组,计算你不触动警报装置的情况下,一夜之内能够偷窃到的最高金额。

思路一:动态规划

c语言解法

cpp 复制代码
int rob(int* nums, int numsSize){
    if (numsSize == 1) {
        return nums[0];
    }
    int dp[numsSize];
    dp[0] = nums[0];
    dp[1] = fmax(nums[0],nums[1]);
    for(int i = 2;i<numsSize;i++)
    {
        dp[i] = fmax(dp[i-1],dp[i-2]+nums[i]);
    }
    return dp[numsSize-1];
}

c++解法

cpp 复制代码
class Solution {
public:
    int rob(vector<int>& nums) {
        if (nums.empty()) {
            return 0;
        }
        int size = nums.size();
        if (size == 1) {
            return nums[0];
        }
        vector<int> dp = vector<int>(size, 0);
        dp[0] = nums[0];
        dp[1] = max(nums[0], nums[1]);
        for (int i = 2; i < size; i++) {
            dp[i] = max(dp[i - 2] + nums[i], dp[i - 1]);
        }
        return dp[size - 1];
    }
};

分析:

本题算动态规划的一道经典例题,理解前后关系后利用动态规划可解决,状态方程为 dp[i] = max(dp[i - 2] + nums[i], dp[i - 1]);即后一位所能偷的最大金额为前一位的最大金额和前两位的最大金额加上当前金额,可依据此题求解其他相似类型的题如:打家劫舍Ⅱ等

总结:

本题考察动态规划的应用,利用动态规划将前一天的最大金额作为求解下一天的条件得到答案,除此之外还可用记忆化递归来进行查找

相关推荐
sin_hielo8 分钟前
leetcode 955
数据结构·算法·leetcode
YJlio11 分钟前
FindLinks 学习笔记(12.4):NTFS 硬链接扫描与文件“多重身份”排查
笔记·学习·intellij-idea
QT 小鲜肉20 分钟前
【Linux命令大全】001.文件管理之diff命令(实操篇)
linux·运维·chrome·笔记
Ahtacca22 分钟前
保姆级教程:Obsidian + PicGo + Gitee 搭建免费稳定的自动化图床
运维·笔记·学习·gitee·自动化
苦 涩24 分钟前
考研408笔记之计算机组成原理(二)——数据的表示和运算
笔记·计算机组成原理·考研408
TechNomad24 分钟前
二分搜索算法的介绍和使用
算法
一起养小猫25 分钟前
LeetCode100天Day4-盛最多水的容器与两数之和II
java·数据结构·算法·leetcode
xie_pin_an37 分钟前
深入解析 C 语言排序算法:从快排优化到外排序实现
c语言·算法·排序算法
ZHang......39 分钟前
synchronized(三)
开发语言·笔记·juc
Hcoco_me41 分钟前
机器学习核心概念与主流算法(通俗详细版)
人工智能·算法·机器学习·数据挖掘·聚类