社区讨论

求助

P4084[USACO17DEC] Barn Painting G参与者 3已保存回复 4

讨论操作

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

当前回复
4 条
当前快照
1 份
快照标识符
@lo7plv7s
此快照首次捕获于
2023/10/27 05:41
2 年前
此快照最后确认于
2023/10/27 05:41
2 年前
查看原帖
CPP
#include <iostream>
#include <vector>
using namespace std;

vector<int> son[100001];
long long dp[100001][3];
bool have[100001];
bool root[100001];

const int mod = 1000000007;

int dp2(int u, int c, int f)
{
	if (have[u])
	{
		return dp[u][c];
	}

	have[u] = true;
	for (int i = 0; i < son[u].size(); i++)
	{
		if (son[u][i] == f)
		{
			continue;
		}
		dp[u][0] *= (dp2(son[u][i], 1, u) + dp2(son[u][i], 2, u)) % mod;
		dp[u][1] *= (dp2(son[u][i], 0, u) + dp2(son[u][i], 2, u)) % mod;
		dp[u][2] *= (dp2(son[u][i], 0, u) + dp2(son[u][i], 1, u)) % mod;
	}
	return dp[u][c];
}

int main()
{
	int n, k;
	cin >> n >> k;

	for (int i = 1; i <= n; i++)
	{
		dp[i][0] = 1;
		dp[i][1] = 1;
		dp[i][2] = 1;
	}

	for (int i = 1; i < n; i++)
	{
		int a, b;
		cin >> a >> b;
		son[a].push_back(b);
		son[b].push_back(a);
		root[b] = true;
	}
	for (int i = 0; i < k; i++)
	{
		int u, c;
		cin >> u >> c;
		c--;
		dp[u][0] = (c == 0 ? 1 : 0);
		dp[u][1] = (c == 1 ? 1 : 0);
		dp[u][2] = (c == 2 ? 1 : 0);
	}

	int r = 1;
	cout << dp2(r, 0, -1) + dp2(r, 1, -1) + dp2(r, 2, -1);
	return 0;
}
用的记搜,但第4组输出0

回复

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

正在加载回复...