GSEP 6级T1真题 [202312] 闯关游戏

题目描述

[GESP202312 六级] 闯关游戏

题目描述

你来到了一个闯关游戏。

这个游戏总共有 N 关,每关都有 M 个通道,你需要选择一个通道并通往后续关卡。其中,第 i 个通道可以让你前进 ai 关,也就是说,如果你现在在第 x 关,那么选择第 i 个通道后,你将直接来到第 x+ai 关(特别地,如果 x+ai≥N,那么你就通关了)。此外,当你顺利离开第 s 关时,你还将获得 bs 分。

游戏开始时,你在第 0 关。请问,你通关时最多能获得多少总分。

输入格式

第一行两个整数 N,M,分别表示关卡数量和每关的通道数量。

接下来一行 M 个用单个空格隔开的整数 a0,a1⋯,aM−1。保证 1≤ai≤N。

接下来一行 N 个用单个空格隔开的整数 b0,b1⋯,bN−1。保证 |bi|≤105。

输出格式

一行一个整数,表示你通关时最多能够获得的分数。

样例 #1

样例输入 #1

6 2 
2 3
1 0 30 100 30 30

样例输出 #1

131

样例 #2

样例输入 #2

6 2
2 3
1 0 30 100 30 -1

样例输出 #2

101

提示

样例解释 1

你可以在第 0 关选择第 1 个通道,获得 1 分并来到第 3 关;随后再选择第 0 个通道,获得 100 分并来到第 5 关;最后任选一个通道,都可以获得 30 分并通关。如此,总得分为 1+100+30=131。

样例解释 2

请注意,一些关卡的得分可能是负数。

数据范围

对于 20 的测试点,保证 M=1。

对于 40 的测试点,保证 N≤20;保证 M≤2。

对于所有测试点,保证 1≤N≤104;保证 1≤M≤100。

样例输入 复制
6 2
2 3
1 0 30 100 30 30
样例输出 复制
131

AC代码:

#include<bits/stdc++.h>
using namespace std;
int n, m, a[105], b[20005], dp[20005];
int main() {
	cin >> n >> m;
	for (int i = 0; i < m; i++) cin >> a[i];
	for (int i = 0; i < n; i++) cin >> b[i];
	dp[0] = b[0];
	for (int i = 1; i < n * 2; i++) {
		dp[i] = -1e8;
		for (int j = 0; j < m; j++) {
			if (i - a[j] >= 0 && dp[i - a[j]] != -1e8) {
				dp[i] = max(dp[i], dp[i - a[j]] + b[i]);
			}
		}
	}
	int ans = -1000000001;
	for (int i = n - 1; i < n * 2; i++) {
		ans = max(ans, dp[i]);
	}
	cout << ans;
	return 0;
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值