Please sign in first.
Submission #7625282
Source Code Expand
#pragma GCC optimize ("Ofast")
#include<bits/stdc++.h>
using namespace std;
#define MD 1000000007
struct mint{
static unsigned md;
static unsigned W;
static unsigned R;
static unsigned Rinv;
static unsigned mdninv;
static unsigned RR;
unsigned val;
mint(){
}
mint(int a){
val = mulR(a);
}
mint(unsigned a){
val = mulR(a);
}
mint(long long a){
val = mulR(a);
}
mint(unsigned long long a){
val = mulR(a);
}
int get_inv(long long a, int md){
long long t=a;
long long s=md;
long long u=1;
long long v=0;
long long e;
while(s){
e=t/s;
t-=e*s;
u-=e*v;
swap(t,s);
swap(u,v);
}
if(u<0){
u+=md;
}
return u;
}
void setmod(unsigned m){
int i;
unsigned t;
W = 32;
md = m;
R = (1ULL << W) % md;
RR = (unsigned long long)R*R % md;
switch(m){
case 104857601:
Rinv = 2560000;
mdninv = 104857599;
break;
case 998244353:
Rinv = 232013824;
mdninv = 998244351;
break;
case 1000000007:
Rinv = 518424770;
mdninv = 2226617417U;
break;
case 1000000009:
Rinv = 171601999;
mdninv = 737024967;
break;
case 1004535809:
Rinv = 234947584;
mdninv = 1004535807;
break;
case 1007681537:
Rinv = 236421376;
mdninv = 1007681535;
break;
case 1012924417:
Rinv = 238887936;
mdninv = 1012924415;
break;
case 1045430273:
Rinv = 254466304;
mdninv = 1045430271;
break;
case 1051721729:
Rinv = 257538304;
mdninv = 1051721727;
break;
default:
Rinv = get_inv(R, md);
mdninv = 0;
t = 0;
for(i=(0);i<((int)W);i++){
if(t%2==0){
t+=md;
mdninv |= (1U<<i);
}
t /= 2;
}
}
}
unsigned mulR(unsigned a){
return (unsigned long long)a*R%md;
}
unsigned mulR(int a){
if(a < 0){
a = a%((int)md)+(int)md;
}
return mulR((unsigned)a);
}
unsigned mulR(unsigned long long a){
return mulR((unsigned)(a%md));
}
unsigned mulR(long long a){
a %= md;
if(a < 0){
a += md;
}
return mulR((unsigned)a);
}
unsigned reduce(unsigned T){
unsigned m = T * mdninv;
unsigned t = (unsigned)((T + (unsigned long long)m*md) >> W);
if(t >= md){
t -= md;
}
return t;
}
unsigned reduce(unsigned long long T){
unsigned m = (unsigned)T * mdninv;
unsigned t = (unsigned)((T + (unsigned long long)m*md) >> W);
if(t >= md){
t -= md;
}
return t;
}
unsigned get(){
return reduce(val);
}
mint &operator+=(mint a){
val += a.val;
if(val >= md){
val -= md;
}
return *this;
}
mint &operator-=(mint a){
if(val < a.val){
val = val + md - a.val;
}
else{
val -= a.val;
}
return *this;
}
mint &operator*=(mint a){
val = reduce((unsigned long long)val*a.val);
return *this;
}
mint &operator/=(mint a){
return *this *= a.inverse();
}
mint operator+(mint a){
return mint(*this)+=a;
}
mint operator-(mint a){
return mint(*this)-=a;
}
mint operator*(mint a){
return mint(*this)*=a;
}
mint operator/(mint a){
return mint(*this)/=a;
}
mint operator+(int a){
return mint(*this)+=mint(a);
}
mint operator-(int a){
return mint(*this)-=mint(a);
}
mint operator*(int a){
return mint(*this)*=mint(a);
}
mint operator/(int a){
return mint(*this)/=mint(a);
}
mint operator+(long long a){
return mint(*this)+=mint(a);
}
mint operator-(long long a){
return mint(*this)-=mint(a);
}
mint operator*(long long a){
return mint(*this)*=mint(a);
}
mint operator/(long long a){
return mint(*this)/=mint(a);
}
mint operator-(void){
mint res;
if(val){
res.val=md-val;
}
else{
res.val=0;
}
return res;
}
operator bool(void){
return val!=0;
}
operator int(void){
return get();
}
operator long long(void){
return get();
}
mint inverse(){
int a = val;
int b = md;
int u = 1;
int v = 0;
int t;
mint res;
while(b){
t = a / b;
a -= t * b;
swap(a, b);
u -= t * v;
swap(u, v);
}
if(u < 0){
u += md;
}
res.val = (unsigned long long)u*RR % md;
return res;
}
mint pw(unsigned long long b){
mint a(*this);
mint res;
res.val = R;
while(b){
if(b&1){
res *= a;
}
b >>= 1;
a *= a;
}
return res;
}
bool operator==(int a){
return mulR(a)==val;
}
bool operator!=(int a){
return mulR(a)!=val;
}
}
;
unsigned mint::md;
unsigned mint::W;
unsigned mint::R;
unsigned mint::Rinv;
unsigned mint::mdninv;
unsigned mint::RR;
mint operator+(int a, mint b){
return mint(a)+=b;
}
mint operator-(int a, mint b){
return mint(a)-=b;
}
mint operator*(int a, mint b){
return mint(a)*=b;
}
mint operator/(int a, mint b){
return mint(a)/=b;
}
mint operator+(long long a, mint b){
return mint(a)+=b;
}
mint operator-(long long a, mint b){
return mint(a)-=b;
}
mint operator*(long long a, mint b){
return mint(a)*=b;
}
mint operator/(long long a, mint b){
return mint(a)/=b;
}
inline void rd(int &x){
int k;
int m=0;
x=0;
for(;;){
k = getchar_unlocked();
if(k=='-'){
m=1;
break;
}
if('0'<=k&&k<='9'){
x=k-'0';
break;
}
}
for(;;){
k = getchar_unlocked();
if(k<'0'||k>'9'){
break;
}
x=x*10+k-'0';
}
if(m){
x=-x;
}
}
inline void rd(char &c){
int i;
for(;;){
i = getchar_unlocked();
if(i!=' '&&i!='\n'&&i!='\r'&&i!='\t'&&i!=EOF){
break;
}
}
c = i;
}
inline int rd(char c[]){
int i;
int sz = 0;
for(;;){
i = getchar_unlocked();
if(i!=' '&&i!='\n'&&i!='\r'&&i!='\t'&&i!=EOF){
break;
}
}
c[sz++] = i;
for(;;){
i = getchar_unlocked();
if(i==' '||i=='\n'||i=='\r'||i=='\t'||i==EOF){
break;
}
c[sz++] = i;
}
c[sz]='\0';
return sz;
}
inline void wt_L(char a){
putchar_unlocked(a);
}
inline void wt_L(int x){
int s=0;
int m=0;
char f[10];
if(x<0){
m=1;
x=-x;
}
while(x){
f[s++]=x%10;
x/=10;
}
if(!s){
f[s++]=0;
}
if(m){
putchar_unlocked('-');
}
while(s--){
putchar_unlocked(f[s]+'0');
}
}
inline void wt_L(mint x){
int i;
i = (int)x;
wt_L(i);
}
int N;
char S[200002];
int main(){
{
mint x;
x.setmod(MD);
}
int i;
int k;
mint res;
rd(N);
rd(S);
res = 1;
for(i=(0);i<(N);i++){
res *= i+1;
}
N *= 2;
for(i=(0);i<(N);i++){
if(S[i]=='W'){
S[i] =0;
}
else{
S[i] =1;
}
}
k = 0;
for(i=(0);i<(N);i++){
if( (k+S[i])%2 ){
k++;
}
else{
res *= k--;
}
}
if(k){
res = 0;
}
wt_L(res);
wt_L('\n');
return 0;
}
// cLay varsion 20190921-1
// --- original code ---
// int N;
// char S[200002];
// {
// int i, k;
// mint res;
//
// rd(N,S);
//
// res = 1;
// rep(i,N) res *= i+1;
// N *= 2;
//
// rep(i,N) S[i] = if[S[i]=='W', 0, 1];
//
// k = 0;
// rep(i,N){
// if( (k+S[i])%2 ) k++;
// else res *= k--;
// }
// if(k) res = 0;
//
// wt(res);
// }
Submission Info
| Submission Time | |
|---|---|
| Task | C - Cell Inversion |
| User | LayCurse |
| Language | C++14 (GCC 5.4.1) |
| Score | 500 |
| Code Size | 7797 Byte |
| Status | AC |
| Exec Time | 5 ms |
| Memory | 384 KiB |
Judge Result
| Set Name | All | Sample | ||||
|---|---|---|---|---|---|---|
| Score / Max Score | 500 / 500 | 0 / 0 | ||||
| Status |
|
|
| Set Name | Test Cases |
|---|---|
| All | sample_01, sample_02, sample_03, testcase_01, testcase_02, testcase_03, testcase_04, testcase_05, testcase_06, testcase_07, testcase_08, testcase_09, testcase_10, testcase_11, testcase_12, testcase_13, testcase_14, testcase_15, testcase_16, testcase_17, testcase_18, testcase_19, testcase_20, testcase_21, testcase_22, testcase_23, testcase_24, testcase_25, testcase_26, testcase_27, testcase_28, testcase_29, testcase_30, testcase_31, testcase_32, testcase_33 |
| Sample | sample_01, sample_02, sample_03 |
| Case Name | Status | Exec Time | Memory |
|---|---|---|---|
| sample_01 | AC | 1 ms | 256 KiB |
| sample_02 | AC | 1 ms | 256 KiB |
| sample_03 | AC | 1 ms | 256 KiB |
| testcase_01 | AC | 3 ms | 384 KiB |
| testcase_02 | AC | 3 ms | 384 KiB |
| testcase_03 | AC | 5 ms | 384 KiB |
| testcase_04 | AC | 2 ms | 256 KiB |
| testcase_05 | AC | 3 ms | 384 KiB |
| testcase_06 | AC | 2 ms | 256 KiB |
| testcase_07 | AC | 3 ms | 384 KiB |
| testcase_08 | AC | 4 ms | 384 KiB |
| testcase_09 | AC | 4 ms | 384 KiB |
| testcase_10 | AC | 1 ms | 256 KiB |
| testcase_11 | AC | 2 ms | 256 KiB |
| testcase_12 | AC | 5 ms | 384 KiB |
| testcase_13 | AC | 4 ms | 384 KiB |
| testcase_14 | AC | 3 ms | 384 KiB |
| testcase_15 | AC | 4 ms | 384 KiB |
| testcase_16 | AC | 3 ms | 384 KiB |
| testcase_17 | AC | 4 ms | 384 KiB |
| testcase_18 | AC | 3 ms | 384 KiB |
| testcase_19 | AC | 4 ms | 384 KiB |
| testcase_20 | AC | 2 ms | 256 KiB |
| testcase_21 | AC | 4 ms | 384 KiB |
| testcase_22 | AC | 4 ms | 384 KiB |
| testcase_23 | AC | 3 ms | 384 KiB |
| testcase_24 | AC | 4 ms | 384 KiB |
| testcase_25 | AC | 4 ms | 384 KiB |
| testcase_26 | AC | 1 ms | 256 KiB |
| testcase_27 | AC | 1 ms | 256 KiB |
| testcase_28 | AC | 4 ms | 384 KiB |
| testcase_29 | AC | 4 ms | 384 KiB |
| testcase_30 | AC | 4 ms | 384 KiB |
| testcase_31 | AC | 4 ms | 384 KiB |
| testcase_32 | AC | 3 ms | 384 KiB |
| testcase_33 | AC | 5 ms | 384 KiB |