#pragma GCC target("avx") #pragma GCC optimize("O3") #pragma GCC optimize("unroll-loops") #include #define mod 1000000007 void p(unsigned int* x,const unsigned int y){ *x+=y; if(*x>=mod)*x-=mod; } unsigned int dp[2][10]; char x,s[8]; int main(){ gets(s,8); dp[0][0]=1; while(~(x=getchar())){ switch(x){ case '?': for(unsigned int j=0;j<9;++j)p(&dp[1][j+1],dp[0][j]); break; case 'y': p(&dp[0][1],dp[0][0]); p(&dp[1][1],dp[1][0]); break; case 'u': p(&dp[0][2],dp[0][1]); p(&dp[1][2],dp[1][1]); break; case 'k': p(&dp[0][3],dp[0][2]); p(&dp[1][3],dp[1][2]); break; case 'i': p(&dp[0][4],dp[0][3]); p(&dp[1][4],dp[1][3]); break; case 'c': p(&dp[0][5],dp[0][4]); p(&dp[1][5],dp[1][4]); break; case 'o': p(&dp[0][6],dp[0][5]); p(&dp[1][6],dp[1][5]); break; case 'd': p(&dp[0][7],dp[0][6]); p(&dp[1][7],dp[1][6]); break; case 'e': p(&dp[0][8],dp[0][7]); p(&dp[1][8],dp[1][7]); break; case 'r': p(&dp[0][9],dp[0][8]); p(&dp[1][9],dp[1][8]); break; } } p(&dp[0][9],dp[1][9]); printf("%u\n",dp[0][9]); }