按摩师(动态规划)

一个有名的按摩师会收到源源不断的预约请求,每个预约都可以选择接或不接。在每次预约 服务之间要有休息时间,因此她不能接受相邻的预约。给定一个预约请求序列,替按摩师找到最 优的预约集合(总预约时间最长),返回总的分钟数。

注意:本题相对原题稍作改动

复制代码
#include<iostream>
#include<vector>
using namespace std;

int MaxVal(int* num, int n)
{
	if (n == 1)	return num[1];
	if (n == 2)	return num[1] > num[2] ? num[1] : num[2];
	vector<int> dp(n + 1, 0);
	dp[1] = num[1];
	for (int i = 2; i <= n; ++i)
	{
		dp[i] = max(dp[i - 1], num[i] + dp[i - 2]);
	}
	return dp[n];
}
int main()
{
	int num[] = { 0,2,7,9,3,1 };
	int n = sizeof(num) / sizeof(num[0]);
	int maxval = MaxVal(num, n);
	cout << maxval << endl;
	return 0;
}
相关推荐
2501_945423541 分钟前
C++编译期多态实现
开发语言·c++·算法
2401_879693871 分钟前
设计模式在C++中的实现
开发语言·c++·算法
☆5665 分钟前
C++中的代理模式高级应用
开发语言·c++·算法
2301_818419016 分钟前
编译器命令选项优化
开发语言·c++·算法
m0_518019486 分钟前
C++图形编程(OpenGL)
开发语言·c++·算法
Jasmine_llq7 分钟前
《B4354 [GESP202506 一级] 假期阅读》
数据结构·算法·最值筛选算法(核心逻辑)·三元运算符简化分支算法·多输入顺序处理算法·整数算术运算算法·格式化输出算法
2301_8166512210 分钟前
自定义异常类设计
开发语言·c++·算法
weixin_4219226911 分钟前
C++与自动驾驶系统
开发语言·c++·算法
算法鑫探15 分钟前
C语言结构体:学生信息统计实战
c语言·数据结构·算法·新人首发
2501_9454248021 分钟前
高性能计算资源调度
开发语言·c++·算法