#define MD 998244353 string@s; ll@k,n=s.size()/2; Matrix m(n+1,n+1); rep(y,n+1){ rep(x,n+1){ m[y][x]= y==x-1 ? x*x: y==x ? n*(n*2-1)-(n-x)*(n-x)-x*x: y==x+1 ? (n-x)*(n-x): 0; } } m**=k; Mint d[102][101]; d[1][1]=1; long t=1; rep(i,1,n*2){ if(s[i]=='('){ t+=1; rrep(j,t){ rrep(k,i/2,min(n,i+1)){ d[j+1][k+1]=d[j][k+1]+d[j+1][k]; } d[j+1][i/2]=0; } }else{ rrep(j,t){ rrep(k,i/2,min(n,i+1)){ d[j+1][k+1]+=d[j+1][k]; } d[j+1][i/2]=0; } } } Combc; Mint z=0; rep(i,n){ z+=m[i][0]/c.C(n,i)**2*d[i+1][n]; } wt(z);