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

动态规划 —— dp问题-按摩师

1. 按摩师

题目链接:

面试题 17.16. 按摩师 - 力扣(LeetCode)icon-default.png?t=O83Ahttps://leetcode.cn/problems/the-masseuse-lcci/description/


2.  算法原理 

状态表示:以某一个位置为结尾或者以某一个位置为起点

   

dp[i]表示:选择到i位置的时候,此时的最长预约时长分两种情况:

    

        1.f[i]表示:选择到i位置的时候,当前位置nums[i]必选,此时的最长预约时长

    

        2.g[i]表示:选择到i位置的时候,当前位置nums[i]不选,此时的最长预约时长

   

2. 状态转移方程

  

根据最近的一步来划分问题:

   

到达dp[i][j]有两种情况:

    

  1. f[i]=g[i-1] + nums[i]

 2. g[i]:a. 当选择i-1的位置时:f[i-1]

    

              b.当不选择i-1的位置时:g[i-1]

   

        g[i]=max(f[i-1],g[i-1])

3. 初始化 :把dp表填满不越界,让后面的填表可以顺利进行

    

本题初始化为:f[0]=nums[0]    g[0]在vector填表的时候默认为0

4. 填表顺序 

    

本题的填表顺序是:从左往右,两个表一起填

5. 返回值 :题目要求 + 状态表示 

    

本题的返回值是:max(f[n-1],g[n-1])


3.代码

动态规划的固定四步骤:1.  创建一个dp表

                                        2. 在填表之前初始化

                                        3. 填表(填表方法:状态转移方程)

                                        4. 确定返回值 

class Solution {
public:int massage(vector<int>& nums) {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]);}
};

完结撒花~


http://www.mrgr.cn/news/66258.html

相关文章:

  • 达梦数据库和人大金仓数据库对数据库的运行查看情况
  • springboot使用kafka推送数据到服务端,带认证
  • 第100+31步 ChatGPT学习:概率校准 Quantile Calibration
  • 【ACM出版,EI稳定检索】2024年人工智能、数字媒体技术与交互设计国际学术会议(ICADI 2024,11月29-12月1日)
  • c#(asp.net) 如何计算两个日期之间相隔天数
  • 【Git】Git 远程仓库命令详解
  • Docker 的基本概念和优势
  • 气体传感器种类详解:从半导体到红外吸收型的全面解析
  • 仿真APP助力汽车零部件厂商打造核心竞争力
  • 解决从huggingface.co下载模型失败问题
  • EasyQBlog .NET 8 + Q-Blog 2.0博客模板 + easyweb iframe后台模板 开发的个人博客
  • 树莓派开发相关知识十 -小车服务器
  • Python打包脚本为EXE可执行文件
  • 信息安全工程师(77)常见网络安全应急事件场景与处理流程
  • 基于SSD模型的行人跌倒、摔倒检测系统,支持图像、视频和摄像实时检测【pytorch框架、python源码】
  • segformer模型实现pcb缺陷检测
  • DMRl-Former用于工业过程预测建模和关键样本分析的数据模式相关可解释Transformer网络
  • vos3000外呼系统如何检查落地网关配置正常,路由分析
  • 为什么学习Mybatis框架
  • Vue3安装、创建到使用
  • 2025郑州国际台球及配套设施展会,台球盛宴,产业新篇
  • 判断图中是否存在环
  • 修正Z-score检验异常值
  • React 前端如何通过组件完成 “下载 Excel模板” 和 “上传 Excel 文件并读取内容生成可使用的对象数组”
  • Linux(文件管理 图片+大白话)
  • 人工智能学习--归一化(Normalization)