社区讨论

dfs30分求助

P1541[NOIP 2010 提高组] 乌龟棋参与者 7已保存回复 7

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
7 条
当前快照
1 份
快照标识符
@lo8ox5bv
此快照首次捕获于
2023/10/27 22:10
2 年前
此快照最后确认于
2023/10/27 22:10
2 年前
查看原帖
rt,剩下7个点全tle了……
CPP
#include <bits/stdc++.h>
using namespace std;
const int N=1e7+10;
int n,m,maxn;
int a[N],b[N];
int flag[N],cnt[N];
void dfs(int pos,int score)
{
	if (pos==n)
	{
		maxn=max(maxn,score);
		return;
	}
	for (int i=1;i<=4;i++)
	{
		if (cnt[i]>=1)
		{
			cnt[i]--;
			dfs(pos+i,score+a[pos+i]);
			cnt[i]++;
		}
	}
}

int main()
{
	cin >> n >> m;
	for (int i=1;i<=n;i++)
		cin >> a[i];
	for (int i=1;i<=m;i++)
		cin >> b[i],cnt[b[i]]++;
	dfs(1,a[1]);
	cout << maxn << endl;
	return 0;
}

回复

7 条回复,欢迎继续交流。

正在加载回复...