比赛 2024国庆练习1 评测结果 AAAAAAAAAA
题目名称 森林大礼包 最终得分 100
用户昵称 flyfree 运行时间 0.560 s
代码语言 C++ 内存使用 9.25 MiB
提交时间 2024-10-04 16:05:06
显示代码纯文本
#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define MAXN 1000010
#define mod 1000000007
inline ll read(){
	ll x=0,f=1;
	char c=getchar();
	while(c<'0'||c>'9'){
		if(c=='-')f=-1;
		c=getchar();
	}
	while(c>='0'&&c<='9'){
		x=x*10+c-'0';
		c=getchar();
	}
	return x*f;
}
ll n,idx;
ll k[MAXN],siz[MAXN];
ll hd[MAXN],ed[MAXN],nxt[MAXN];
queue <ll> q;
void build(ll x,ll y){
	nxt[++idx]=hd[x];
	ed[idx]=y;
	hd[x]=idx;
}
int main(){
	freopen("three_squirrels.in","r",stdin);
	freopen("three_squirrels.out","w",stdout);
	n=read();
	for(int i=1;i<=n;i++){
		k[i]=read();
		for(int j=1;j<=k[i];j++){
			ll a=read();
			build(a,i);
		}
	}
	siz[0]=1;
	q.push(0);
	while(!q.empty()){
		ll fnt=q.front();
		q.pop();
		for(int i=hd[fnt];i;i=nxt[i]){
			ll y=ed[i];
			siz[y]=(siz[y]+siz[fnt])%mod;
			k[y]--;
			if(!k[y]){
				q.push(y);
			}
		}
	}
	cout<<siz[n];
	return 0;
}