83、动态规划-打家劫舍

server/2024/9/25 3:38:52/

思路:

首先使用递归方式求出最优解。从每个房屋开始,分别考虑偷与不偷两种情况,然后递归地对后续的房屋做同样的决策。这种方法确保了可以找到在不触发警报的情况下可能的最高金额。

代码如下:

public static int rob(int[] nums) {if (nums == null || nums.length == 0) {return 0;  // 如果没有房屋可偷,则返回0}// 递归求解最大金额return process(nums, 0, nums.length);
}private static int process(int[] nums, int index, int N) {if (index >= N) {return 0;  // 超出数组范围,返回0}// 偷当前房屋并跳过下一个房屋int p1 = nums[index] + process(nums, index + 2, N);// 不偷当前房屋,考虑下一个房屋int p2 = process(nums, index + 1, N);// 返回两种方案中的最大值return Math.max(p1, p2);
}

但是递归方式会有重复计算,知道了思路来改成动态规划就很容易。dp[N]=0,超出长度,dp[n-1]=nums[n-1]表示从n-1开始最优抢多少金额,那只能抢一家。然后开始递归。dp状态转移方程就是Math.max(nums[i] + dp[i + 2], dp[i + 1]);代码如下:

class Solution {public static int rob(int[] nums) {// 检查输入数组是否为空,如果为空或长度为0,则直接返回0,因为没有什么可以偷的if (nums == null || nums.length == 0) {return 0;}// 获取数组的长度,即房屋的数量int N = nums.length; // 创建一个动态规划数组,长度为N+1,用来存储到每个房屋为止的最大偷窃金额int[] dp = new int[N + 1]; // 数组最后一个元素设为0,表示超过最后一个房屋后没有可偷的金额dp[N] = 0;  // 初始化最后一间房屋的情况,只有一个选择,就是偷这间房屋dp[N - 1] = nums[N - 1];  // 从倒数第二个房间开始向前计算每个房间的最大偷窃金额for (int i = N - 2; i >= 0; i--) {// 如果偷当前房屋i,那么下一个可偷的房屋是i+2,总金额是当前房屋的金额加上dp[i+2]int p1 = nums[i] + dp[i + 2]; // 如果不偷当前房屋i,那么考虑从下一个房屋i+1开始的最大金额int p2 = dp[i + 1];  // 对于当前房屋i,选择偷与不偷的最大值作为dp[i]的值dp[i] = Math.max(p1, p2);}// 返回从第一间房屋开始偷窃的最大金额,即dp数组的第一个元素return dp[0];
}}


http://www.ppmy.cn/server/31616.html

相关文章

triton之normalization教程

一 前向 在上式中,x是代表一个tensor import torchimport triton import triton.language as tltry:# This is https://github.com/NVIDIA/apex, NOT the apex on PyPi, so it# should not be added to extras_require in setup.py.import apexHAS_APEX = True except Module…

中国电子学会(CEIT)2022年09月真题C语言软件编程等级考试三级(含详细解析答案)

中国电子学会(CEIT)考评中心历届真题(含解析答案) C语言软件编程等级考试三级 2022年09月 编程题五道 总分:100分一、课程冲突(25分) 小A修了n门课程,第ii门课程是从第ai天一直上到第bi天。定义两门课程的冲突程度为∶有几天是这两门课程都要上的。例如a1=1,b1=3…

【计算机网络】第一章——计算机概述(下篇)

个人主页:兜里有颗棉花糖 欢迎 点赞👍 收藏✨ 留言✉ 加关注💓本文由 兜里有颗棉花糖 原创 收录于专栏【计算机网络】 本专栏旨在分享学习计算机网络的一点学习笔记,欢迎大家在评论区交流讨论💌 目录 一、主机端二、路…

【Linux】初识进程

目录 一、进程的概念与定义 二、进程的描述-PCB 三、fork() 函数 四、进程状态 五、僵尸进程 六、孤儿进程 一、进程的概念与定义 进程是计算机系统中正在运行的程序的实例。它是操作系统对程序执行的基本单位,可以看作是程序在执行过程中的动态表现。每个进…

HttpUtil的定义

1.提供发送http请求的方法,Get、Post、Delete、Put // 这段代码主要用于发送 HTTP 请求,支持 GET、POST、PUT 和 DELETE 方法,同时支持发送 URL 查询字符串和请求体。下面是加上中文注释后的代码: package com.wyh.chat.util;imp…

在Ubuntu上怎么卸载qemu-system-x86_64

2024年5月3日,周五晚上 要在Ubuntu上卸载QEMU,你可以使用以下命令: sudo apt remove qemu-system-x86这个命令将卸载QEMU系统模拟器(x86架构)。你也可以使用purge参数来彻底删除QEMU及其配置文件: sudo a…

【微服务】——Docker 基础知识

这里写自定义目录标题 1.1 了解Docker1.1.1应用部署的环境问题1.1.2.Docker解决依赖兼容问题1.1.3.Docker解决操作系统环境差异1.1.4.小结 1.2.Docker和虚拟机的区别1.3.Docker架构1.3.1.镜像和容器1.3.2.DockerHub1.3.3.Docker架构1.3.4.小结 1.4.安装Docker——未实践 2.Dock…

eSIM与传统SIM卡

有任何关于GSMA\IOT\eSIM\RSP\业务应用场景相关的问题,欢迎W: xiangcunge59 一起讨论, 共同进步 (加的时候请注明: 来自CSDN-iot). ### 什么是eSIM? eSIM(嵌入式SIM)技术旨在解决传统SIM卡的局限性。传统SIM卡是特定于运营商的…