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

简单多状态 dp 问题

11. 按摩师(easy)

解法(动态规划):

图解:

C++ 算法代码:


class Solution {
public:int massage(vector<int>& nums) {// 1. 创建⼀个 dp 表// 2. 初始化// 3. 填表// 4. 返回值int n = nums.size();if (n == 0) return 0; // 处理边界条件vector<int> f(n);auto g = f;f[0] = nums[0];for (int i = 1; i < n; i++){f[i] = g[i - 1] + nums[i];g[i] = max(f[i - 1], g[i - 1]);}return max(f[n - 1], g[n - 1]);}
};

12. 打家劫舍II (medium)

解法(动态规划):

图解:

C++ 算法代码:

class Solution
{
public:int rob(vector<int>& nums) {int n = nums.size();// 两种情况下的最⼤值return max(nums[0] + rob1(nums, 2, n - 2), rob1(nums, 1, n - 1));}int rob1(vector<int>& nums, int left, int right) {if (left > right) return 0;// 1. 创建 dp 表// 2. 初始化// 3. 填表// 4. 返回结果int n = nums.size();vector<int> f(n);auto g = f;f[left] = nums[left]; // 初始化for (int i = left + 1; i <= right; i++){f[i] = g[i - 1] + nums[i];g[i] = max(f[i - 1], g[i - 1]);}return max(f[right], g[right]);}
};

13. 删除并获得点数(medium)

解法(动态规划):

图解:

C++ 算法代码:

class Solution {
public:int deleteAndEarn(vector<int>& nums) {const int N = 10001;// 1. 预处理int arr[N] = { 0 };for (auto x : nums) arr[x] += x;// 2. 在 arr 数组上,做⼀次 “打家劫舍” 问题// 创建 dp 表vector<int> f(N);auto g = f;// 填表for (int i = 1; i < N; i++){f[i] = g[i - 1] + arr[i];g[i] = max(f[i - 1], g[i - 1]);}// 返回结果return max(f[N - 1], g[N - 1]);}
};

14. 粉刷房子(medium)

解法(动态规划):

图解:

C++ 算法代码:

class Solution {
public:int minCost(vector<vector<int>>& costs) {// dp[i][j] 第i个房⼦刷成第j种颜⾊最⼩花费int n = costs.size();vector<vector<int>> dp(n + 1, vector<int>(3));for (int i = 1; i <= n; i++) {dp[i][0] = min(dp[i - 1][1], dp[i - 1][2]) + costs[i - 1][0];dp[i][1] = min(dp[i - 1][0], dp[i - 1][2]) + costs[i - 1][1];dp[i][2] = min(dp[i - 1][1], dp[i - 1][0]) + costs[i - 1][2];}return min(dp[n][0], min(dp[n][1], dp[n][2]));}
}

相关文章:

  • Facebook广告如何开户以及投放费用?
  • MySQL中创建触发器时,语法与创建存储过程或函数的语法有所不同注意
  • RobotFramework测试框架(1)--官网示例
  • ACM实训冲刺第十九天
  • Vue.js组件设计模式:构建可复用组件库
  • SQL Server2019安装步骤教程(图文)_最新教程
  • Gradient-checkpointing的原理
  • 将list对象里的某一个属性取出组成一个新的list
  • PyTorch深度学习快速入门——P1-P13
  • 【python006】miniconda3环境搭建(非root目录,最近更新中)
  • Windows Presentation Foundation(WPF)要点总结
  • 大数据之Hive函数大全
  • 阿里云数据库 SelectDB 版全面商业化,开启现代化实时数据仓库的全新篇章
  • 工具方法 - 如何在网上找资料
  • 领导VS管理:技术团队掌舵者的双重角色解析
  • 【跃迁之路】【477天】刻意练习系列236(2018.05.28)
  • Go 语言编译器的 //go: 详解
  • Java 23种设计模式 之单例模式 7种实现方式
  • Java IO学习笔记一
  • JavaScript 无符号位移运算符 三个大于号 的使用方法
  • jdbc就是这么简单
  • Laravel 菜鸟晋级之路
  • php中curl和soap方式请求服务超时问题
  • Sass 快速入门教程
  • TypeScript迭代器
  • vue的全局变量和全局拦截请求器
  • 前端js -- this指向总结。
  • 前端面试之CSS3新特性
  • 设计模式(12)迭代器模式(讲解+应用)
  • 我与Jetbrains的这些年
  • 新手搭建网站的主要流程
  • 责任链模式的两种实现
  • 自定义函数
  • ​【数据结构与算法】冒泡排序:简单易懂的排序算法解析
  • ​低代码平台的核心价值与优势
  • ​无人机石油管道巡检方案新亮点:灵活准确又高效
  • #Spring-boot高级
  • #WEB前端(HTML属性)
  • (1)(1.9) MSP (version 4.2)
  • (3) cmake编译多个cpp文件
  • (32位汇编 五)mov/add/sub/and/or/xor/not
  • (AngularJS)Angular 控制器之间通信初探
  • (C语言)共用体union的用法举例
  • (delphi11最新学习资料) Object Pascal 学习笔记---第5章第5节(delphi中的指针)
  • (js)循环条件满足时终止循环
  • (WSI分类)WSI分类文献小综述 2024
  • (层次遍历)104. 二叉树的最大深度
  • (附源码)springboot金融新闻信息服务系统 毕业设计651450
  • (附源码)ssm智慧社区管理系统 毕业设计 101635
  • (论文阅读40-45)图像描述1
  • (免费领源码)python#django#mysql公交线路查询系统85021- 计算机毕业设计项目选题推荐
  • (十二)Flink Table API
  • (未解决)jmeter报错之“请在微信客户端打开链接”
  • (转)ABI是什么
  • ../depcomp: line 571: exec: g++: not found