#include #define syosu(x) fixed< P; typedef pair pdd; typedef pair pll; typedef vector vi; typedef vector vvi; typedef vector vd; typedef vector vvd; typedef vector vl; typedef vector vvl; typedef vector vs; typedef vector

vp; typedef vector vvp; typedef vector vpll; typedef pair pip; typedef vector vip; const int inf=1<<27; const ll INF=1ll<<60; const double pi=acos(-1); const double eps=1e-18; //const ll mod=1e9+7; const ll mod=998244353; const int dx[4]={-1,0,1,0},dy[4]={0,-1,0,1}; int n,m; vi a,b,c; int main(){ cin>>n; a=b=c=vi(n+1); for(int i=2;i<=n;i++) cin>>a[i]>>b[i]>>c[i]; cin>>m; for(int i=0;i>x; vl dp(n+1); dp[0]=1;dp[1]=x; for(int j=2;j<=n;j++){ if(a[j]==1) dp[j]=(dp[b[j]]+dp[c[j]])%mod; if(a[j]==2) dp[j]=b[j]*dp[c[j]]%mod; if(a[j]==3) dp[j]=dp[b[j]]*dp[c[j]]%mod; } cout<