#include #include typedef long long int int64; const int mod=998244353; void run(void){ int n; scanf("%d",&n); int t[51]; int a[51]; int b[51]; int i; for(i=2;i<=n;i++){ scanf("%d%d%d",t+i,a+i,b+i); } int64 f[51]; f[0]=1; int q; scanf("%d",&q); for(i=1;i<=q;i++){ int x; scanf("%d",&x); f[1]=x; int k; for(k=2;k<=n;k++){ if(t[k]==1){ f[k]=(f[a[k]]+f[b[k]])%mod; } else if(t[k]==2){ f[k]=a[k]*f[b[k]]%mod; } else { f[k]=f[a[k]]*f[b[k]]%mod; } } printf("%lld\n",f[n]); } return; } int main(void){ run(); return 0; }