当前位置: 首页 > news >正文

动态规划问题 -- 多状态模型(打家劫舍II)

目录

  • 动态规划分析问题五步曲
  • 题目概述
  • 如何分析环的问题(重要)
  • 代码编写

动态规划分析问题五步曲

不清楚动态规划分析问题是哪关键的五步的少年们可以移步到
链接: 动态规划算法基础
这篇文章非常详细的介绍了动态规划算法是如何分析和解决问题的

题目概述

链接: 打家劫舍II
在这里插入图片描述

本题是打家劫舍i的变式,只是把线性问题转化为了环
在写本题之前一定要先写完 “打家劫舍”
链接: 打家劫舍

如何分析环的问题(重要)

直接暴力的处理环是不推荐的,边界的控制很不方便
一定要把环转为线性问题解决

本题把环转换为线性问题的分析过程如下
本题定位问题的关键就是 nums第一个元素和最后一个元素不能同时获取
不妨分类讨论第一个位置

  1. 若偷第一个位置
    偷第一个位置,则下标1和nums末尾受到影响只能不偷
    从下标2开始到下标size()-2位置的元素不会受到影响有偷和不偷两个状态
    在这里插入图片描述

2.若不偷第一个位置
不偷第一个位置,nums其他任意元素都不会受到影响
在这里插入图片描述

结论!!!
如果元素都有两个状态,那么求这段元素能获得的金钱不就是打家劫舍1吗
要把环转化为线性问题,只需要分类讨论
1.第一个偷,则对2到size()-2位置来一次打家劫舍1即可
2.第一个不偷,则对1到size()-1位置来一次打家劫舍1即可

代码编写

有了打家劫舍1的基础和把环形问题转化为线性的理解,我们可以写出非常优雅的代码

    int rob(vector<int>& nums) {     int n = nums.size();if(n == 0) return 0;//来两次打家劫舍1,返回两次的最大值return max(robs(nums,2,n-2)+nums[0] , robs(nums,1,n-1));}//从 nums的begin开始直到end,来一次‘打家劫舍1’int robs(vector<int>& nums , int begin , int end){if(begin > end) return 0;int n = end - begin + 1;vector<int> teal(n);auto noteal = teal;teal[0] = nums[begin];for(int i = 1 ; i < n; i++){teal[i] = noteal[i-1] + nums[i+begin];noteal[i] = max(teal[i-1],noteal[i-1]);}return max(teal[n-1],noteal[n-1]);}

少年,今天你又进步了一点点哟,明天继续加油吧
在这里插入图片描述

相关文章:

  • 基于STM32、HAL库的ADAU1701JSTZ-RL音频接口芯片驱动程序设计
  • 【ArcGIS】根据shp范围生成系列等距点:范围外等距点+渔网点(Python全代码)
  • Windows系统配置WSL2及Cuda
  • 在spark中配置历史服务器
  • Weblogic 反序列化远程命令执行漏洞 CVE-2019-2725 详解
  • 【25软考网工】第六章(5)应用层安全协议
  • vue 中绑定样式 【class样式绑定】
  • 【Ubuntu】扩充磁盘大小
  • langchain提示词的使用
  • 《算法导论(第4版)》阅读笔记:p39-p48
  • 电子电器架构 --- 区域计算架构(Zonal Compute)备战下一代电子电气架构
  • 重庆医科大学附属第二医院外科楼外挡墙自动化监测
  • 保护数据安全的关键一步-安装加密软件
  • 修复aosp中QQ无法跳转到短信的问题
  • 【android bluetooth 框架分析 02】【Module详解 6】【StorageModule 模块介绍】
  • 关于 js:8. 反调试与混淆识别
  • 基于javaweb的SpringBoot酒店管理系统设计与实现(源码+文档+部署讲解)
  • [51单片机]---DS18B20 温度检测
  • MYSQL 的缓存策略(四)
  • python视频拆帧并根据所选区域保存指定区域
  • 阿尔巴尼亚执政党连续第四次赢得议会选举,反对党此前雇用特朗普竞选经理
  • 巴基斯坦全国航班仍持续延误或取消
  • 18世纪“精于剪切、复制、粘贴”的美国新闻界
  • 农林生物安全全国重点实验室启动建设,聚焦重大有害生物防控等
  • 伊朗外长称正与美国进行“善意”的会谈
  • 构筑高地共伴成长,第六届上海创新创业青年50人论坛在沪举行