【学会动态规划】按摩师(11)

目录

动态规划怎么学?

[1. 题目解析](#1. 题目解析)

[2. 算法原理](#2. 算法原理)

[1. 状态表示](#1. 状态表示)

[2. 状态转移方程](#2. 状态转移方程)

[3. 初始化](#3. 初始化)

[4. 填表顺序](#4. 填表顺序)

[5. 返回值](#5. 返回值)

[3. 代码编写](#3. 代码编写)

写在最后:


动态规划怎么学?

学习一个算法没有捷径,更何况是学习动态规划,

跟我一起刷动态规划算法题,一起学会动态规划!

1. 题目解析

题目链接: 面试题 17.16. 按摩师 - 力扣(Leetcode)

题目不难理解,就是不能选相邻的预约请求,。

最后算出最长的预约时长。

2. 算法原理

1. 状态表示

dp[ i ] 表示的是到这个位置的时候的最长预约时长,

但是实际上这里有两种情况,

  1. 到了 i 位置选 i 此时的最长预约时长:我们称之为 f [ i ]

  2. 到了 i 位置但是不选 i 此时的最长预约时长:我们称之为 g [ i ]

2. 状态转移方程

那这两种情况的状态转移方程是什么呢?

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

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

3. 初始化

f [ 0 ] = nums[ 0 ] ,g [ 0 ] = 0

4. 填表顺序

从左往右。

5. 返回值

max( f [ n - 1 ],g[ n - 1 ] ),取最后一个位置的两种情况的最大值

3. 代码编写

cpp 复制代码
class Solution {
public:
    int massage(vector<int>& nums) {
        int size = nums.size();
        if(size == 0) return 0;
        vector<int> f(size);
        auto g = f;
        f[0] = nums[0];
        for(int i = 1; i < size; i++) {
            f[i] = g[i - 1] + nums[i];
            g[i] = max(f[i - 1], g[i - 1]);
        }
        return max(f[size - 1], g[size - 1]);
    }
};

写在最后:

以上就是本篇文章的内容了,感谢你的阅读。

如果感到有所收获的话可以给博主点一个哦。

如果文章内容有遗漏或者错误的地方欢迎私信博主或者在评论区指出~

相关推荐
red_redemption2 分钟前
自由学习记录(116)
学习
zhooyu6 分钟前
C++和OpenGL手搓3D游戏编程(20160207进展和效果)
开发语言·c++·游戏·3d·opengl
HAPPY酷10 分钟前
C++ 和 Python 的“容器”对决:从万金油到核武器
开发语言·c++·python
Jay Kay30 分钟前
GVPO:Group Variance Policy Optimization
人工智能·算法·机器学习
Epiphany.55641 分钟前
蓝桥杯备赛题目-----爆破
算法·职场和发展·蓝桥杯
YuTaoShao1 小时前
【LeetCode 每日一题】1653. 使字符串平衡的最少删除次数——(解法三)DP 空间优化
算法·leetcode·职场和发展
r i c k1 小时前
数据库系统学习笔记
数据库·笔记·学习
茉莉玫瑰花茶1 小时前
C++ 17 详细特性解析(5)
开发语言·c++·算法
野犬寒鸦1 小时前
从零起步学习JVM || 第一章:类加载器与双亲委派机制模型详解
java·jvm·数据库·后端·学习
cpp_25011 小时前
P10570 [JRKSJ R8] 网球
数据结构·c++·算法·题解