算法---动态规划练习-7(按摩师)【类似打家劫舍】

按摩师

  • [1. 题目解析](#1. 题目解析)
  • [2. 讲解算法原理](#2. 讲解算法原理)
  • [3. 编写代码](#3. 编写代码)

1. 题目解析

题目地址点这里

2. 讲解算法原理


  1. 首先,给定一个整数数组 nums,其中 nums[i] 表示第 i 天的预约时间长度

  2. 定义两个辅助数组 f 和 g,长度都为 n(n 是数组 nums 的长度)。

    • 数组 f 表示在第 i 天选择预约时的最大总时长。
    • 数组 g 表示在第 i 天选择不预约时的最大总时长。
  3. 初始化数组 f 和 g 的第一个元素:

    • f[0] = nums[0],表示第一天选择预约,总时长为第一天的预约时长
    • g[0] = 0,表示第一天选择不预约,总时长为0
  4. 从第二天开始,从左到右遍历整个数组 nums,计算每一天的最大总时长

    • 对于第 i 天,如果选择预约,则总时长为前一天选择不预约的最大总时长 g[i-1] 加上第 i 天的预约时长 nums[i],即 f[i] = g[i-1] + nums[i]
    • 对于第 i 天,如果选择不预约,则总时长为前一天选择预约和不预约的最大总时长中的较大值,即 g[i] = max(f[i-1], g[i-1])
  5. 最后,返回最后一天选择预约和不预约的最大总时长的较大值,即 max(f[n-1], g[n-1]),其中 n 是数组 nums 的长度。


3. 编写代码

cpp 复制代码
class Solution {
public:
    int massage(vector<int>& nums) {
        int n=nums.size();
        //处理细节
        if(n==0) return 0;

        vector<int> f(n);   
        vector<int> g(n); 
        f[0]=nums[0],g[0]=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]);
    }
};
相关推荐
晚风吹长发1 天前
初步了解Linux中文件描述符-fd
linux·运维·服务器·c++·开发·文件
赖small强1 天前
【Linux C/C++开发】Linux C/C++ 高效延迟崩溃分析:基于 mprotect 的内存陷阱技术 (Electric Fence)
linux·c语言·c++·mprotect·buffer overflow
繁华似锦respect1 天前
C++ & Linux 中 GDB 调试与内存泄漏检测详解
linux·c语言·开发语言·c++·windows·算法
立志成为大牛的小牛1 天前
数据结构——五十四、处理冲突的方法——开放定址法(王道408)
数据结构·学习·程序人生·考研·算法
子一!!1 天前
数据结构===红黑树===
数据结构
锡兰_CC1 天前
无缝触达,卓越体验:开启openEuler世界的任意门
服务器·网络·数据库·c++·图像处理·qt·nginx
王燕龙(大卫)1 天前
滑动窗口问题记录
c++
代码游侠1 天前
复习——栈、队列、树、哈希表
linux·数据结构·学习·算法
不会代码的小猴1 天前
C++的第十二天笔记
开发语言·c++·笔记
橘子真甜~1 天前
C/C++ Linux网络编程10 - http协议
linux·服务器·网络·c++·网络协议·http