QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#233409 | #7564. Game | ExplodingKonjac | AC ✓ | 1838ms | 123220kb | C++20 | 12.6kb | 2023-10-31 17:20:15 | 2023-10-31 17:20:16 |
Judging History
answer
#include <bits/stdc++.h>
using namespace std;
#define OPENIOBUF
namespace FastIO
{
class FastIOBase
{
protected:
#ifdef OPENIOBUF
static const int BUFSIZE=1<<16;
char buf[BUFSIZE+1];
int buf_p=0;
#endif
FILE *target;
FastIOBase(FILE *f): target(f){}
~FastIOBase()=default;
public:
#ifdef OPENIOBUF
virtual void flush()=0;
#endif
};
class FastOutput final: public FastIOBase
{
public:
FastOutput(FILE *f=stdout): FastIOBase(f) {}
#ifdef OPENIOBUF
~FastOutput() { flush(); }
void flush() { fwrite(buf,1,buf_p,target),buf_p=0; }
#endif
void put(char x)
{
#ifdef OPENIOBUF
if(buf[buf_p++]=x,buf_p==BUFSIZE) flush();
#else
putc(x,target);
#endif
}
FastOutput &operator <<(char x)
{ return put(x),*this; }
FastOutput &operator <<(const char *s)
{ for(;*s;put(*(s++)));return *this; }
FastOutput &operator <<(const std::string &s)
{ return (*this)<<s.c_str(); }
template<typename T>
std::enable_if_t<std::is_integral<T>::value,FastOutput&> operator <<(T x)
{
if(x<0) return put('-'),(*this)<<(-x);
char stk[numeric_limits<T>::digits10+1],*top=stk;
do *(top++)=x%10+'0',x/=10; while(x);
while(top!=stk) put(*(--top));
return *this;
}
template<typename ...T>
void writesp(T &&...x)
{ std::initializer_list<int>{((*this)<<(x),put(' '),0)...}; }
template<typename ...T>
void writeln(T &&...x)
{ std::initializer_list<int>{((*this)<<(x),put('\n'),0)...}; }
template<typename Iter>
void writesp(Iter begin,Iter end)
{ while(begin!=end) (*this)<<*(begin++)<<' '; }
template<typename Iter>
void writeln(Iter begin,Iter end)
{ while(begin!=end) (*this)<<*(begin++)<<'\n'; }
}qout;
class FastInput final: public FastIOBase
{
private:
bool __eof;
public:
FastInput(FILE *f=stdin): FastIOBase(f),__eof(false)
#ifdef OPENIOBUF
{ buf_p=BUFSIZE; }
void flush() { buf[fread(buf,1,BUFSIZE,target)]=EOF,buf_p=0; }
bool eof()const { return buf[buf_p]==EOF; }
#else
{}
bool eof()const { return feof(target); }
#endif
char get()
{
if(__eof) return EOF;
#ifdef OPENIOBUF
if(buf_p==BUFSIZE) flush();
char ch=buf[buf_p++];
#else
char ch=getc(target);
#endif
return ~ch?ch:(__eof=true,EOF);
}
void unget(char c)
{
__eof=false;
#ifdef OPENIOBUF
buf[--buf_p]=c;
#else
ungetc(c,target);
#endif
}
explicit operator bool()const { return !__eof; }
FastInput &operator >>(char &x)
{ while(isspace(x=get()));return *this; }
template<typename T>
std::enable_if_t<std::is_integral<T>::value,FastInput&> operator >>(T &x)
{
char ch,sym=0;x=0;
while(isspace(ch=get()));
if(__eof) return *this;
if(ch=='-') sym=1,ch=get();
for(;isdigit(ch);x=(x<<1)+(x<<3)+(ch^48),ch=get());
return unget(ch),sym?x=-x:x,*this;
}
FastInput &operator >>(char *s)
{
while(isspace(*s=get()));
if(__eof) return *this;
for(;!isspace(*s) && !__eof;*(++s)=get());
return unget(*s),*s='\0',*this;
}
FastInput &operator >>(std::string &s)
{
char str_buf[(1<<8)+1]={0},*p=str_buf;
char *const buf_end=str_buf+(1<<8);
while(isspace(*p=get()));
if(__eof) return *this;
for(s.clear(),p++;;p=str_buf)
{
for(;p!=buf_end && !isspace(*p=get()) && !__eof;p++);
if(p!=buf_end) break;
s.append(str_buf);
}
unget(*p),*p='\0',s.append(str_buf);
return *this;
}
template<typename ...T>
void read(T &&...x)
{ std::initializer_list<int>{((*this)>>(x),0)...}; }
template<typename Iter>
void read(Iter begin,Iter end)
{ while(begin!=end) (*this)>>*(begin++); }
}qin;
} // namespace FastIO
using FastIO::qin,FastIO::qout;
using LL=long long;
using LD=long double;
using UI=unsigned int;
using ULL=unsigned long long;
#ifndef DADALZY
#define FILEIO(file) freopen(file".in","r",stdin),freopen(file".out","w",stdout)
#define LOG(...) [](auto...){}(__VA_ARGS__)
#else
#define FILEIO(file)
#define LOG(...) fprintf(stderr,__VA_ARGS__)
#endif
namespace Math::ZPoly
{
constexpr int MOD=998244353,G=114514,MAXN=1<<21;
inline int qpow(LL a,LL b) { LL r=1;for(;b;(b&1)?r=r*a%MOD:0,a=a*a%MOD,b>>=1);return r; }
inline int madd(int x) { return x; }
inline int mmul(int x) { return x; }
inline int msub(int x,int y) { return (x-=y)<0?x+=MOD:x; }
inline int mdiv(int x,int y) { return (LL)x*qpow(y,MOD-2)%MOD; }
template<typename ...Args> inline int madd(int x,Args ...y) { return (x+=madd(y...))>=MOD?x-=MOD:x; }
template<typename ...Args> inline int mmul(int x,Args ...y) { return (LL)x*mmul(y...)%MOD; }
class PolyTemp
{
private:
static PolyTemp V;
int g[MAXN+5],c1[MAXN+5],c2[MAXN+5];
PolyTemp()
{
int nn=1<<(__lg(MAXN-1)+1);
for(int i=2;i<=nn;i<<=1)
{
g[i>>1]=1;
int gn=qpow(G,(MOD-1)/i);
for(int j=(i>>1)+1;j<i;j++) g[j]=mmul(g[j-1],gn);
}
}
friend class Polynomial;
}PolyTemp::V{};
// A class for polynomials in F_{MOD}.
class Polynomial: public vector<int>
{
private:
static constexpr int NTT_LIM=100;
static constexpr auto &g=PolyTemp::V.g,&c1=PolyTemp::V.c1,&c2=PolyTemp::V.c2;
using BaseT=vector<int>;
#define NTT_CHECK(n,m) (n+m<=NTT_LIM || 1ll*n*m<5ll*(n+m)*__lg(n+m))
#define EXTEND(n) (1<<(__lg((n)-1)+1))
#define MCPY(a,b,s) memcpy(a,b,(s)*sizeof(int))
#define MSET(a,b,s) memset(a,b,(s)*sizeof(int))
public:
static void DIT(int *a,int len)
{
for(int i=len>>1;i;i>>=1)
for(int j=0;j<len;j+=i<<1)
for(int k=0,x,y;k<i;k++)
x=a[j+k],y=a[i+j+k],a[j+k]=madd(x,y),a[i+j+k]=mmul(g[i+k],msub(x,y));
}
static void DIF(int *a,int len)
{
for(int i=1;i<len;i<<=1)
for(int j=0;j<len;j+=i<<1)
for(int k=0,x,y;k<i;k++)
x=a[j+k],y=mmul(g[i+k],a[i+j+k]),a[j+k]=madd(x,y),a[i+j+k]=msub(x,y);
int x=qpow(len,MOD-2);
for(int i=0;i<len;i++) a[i]=mmul(a[i],x);
reverse(a+1,a+len);
}
private:
static void __polyinv(const int *a,int *b,int len)
{
if(len==1) return b[0]=qpow(a[0],MOD-2),void();
__polyinv(a,b,(len+1)>>1);
int nn=EXTEND(len<<1);
MCPY(c1,a,len);
MSET(b+len,0,nn-len);
MSET(c1+len,0,nn-len);
DIT(b,nn),DIT(c1,nn);
for(int i=0;i<nn;i++) b[i]=mmul(b[i],msub(2,mmul(b[i],c1[i])));
DIF(b,nn),MSET(b+len,0,nn-len);
}
static void __polyln(const int *a,int *b,int len)
{
__polyinv(a,b,len);
for(int i=1;i<len;i++) c1[i-1]=mmul(i,a[i]);
int nn=EXTEND(len<<1);
MSET(b+len,0,nn-len);
MSET(c1+len,0,nn-len);
DIT(b,nn),DIT(c1,nn);
for(int i=0;i<nn;i++) b[i]=mmul(b[i],c1[i]);
DIF(b,nn),MSET(b+len,0,nn-len);
for(int i=len-1;i>0;i--) b[i]=mdiv(b[i-1],i);
b[0]=0;
}
static void __polyexp(const int *a,int *b,int l,int r)
{
if(l==r-1) return b[l]=(l?mdiv(b[l],l):1),void();
int len=r-l,mid=(l+r)>>1;
__polyexp(a,b,l,mid);
for(int i=0;i<len;i++) c1[i]=a[i];
MCPY(c2,b+l,mid-l);
MSET(c2+mid-l,0,r-mid);
if(NTT_CHECK(len,len)) for(int i=len-1;i>=0;i--)
{
int tmp=0;
for(int j=0;j<=i;j++)
tmp=madd(tmp,mmul(c1[j],c2[i-j]));
c1[i]=tmp;
}
else
{
DIT(c1,len),DIT(c2,len);
for(int i=0;i<len;i++) c1[i]=mmul(c1[i],c2[i]);
DIF(c1,len);
}
for(int i=mid;i<r;i++) b[i]=madd(b[i],c1[i-l]);
__polyexp(a,b,mid,r);
}
public:
using BaseT::BaseT;
using BaseT::operator=;
int operator ()(int x)const
{
int res=0,sz=size();
for(int i=sz-1;i>=0;i--)
res=madd(mmul(res,x),(*this)[i]);
return res;
}
#define DEF_OP(op) \
Polynomial operator op(const Polynomial &p)const \
{ return Polynomial(*this)op##=p; } \
Polynomial &operator op##=(const Polynomial &p)
DEF_OP(+)
{
int n=size(),m=p.size();
if(n<m) resize(m);
for(int i=0;i<m;i++)
(*this)[i]=madd((*this)[i],p[i]);
return *this;
}
DEF_OP(-)
{
int n=size(),m=p.size();
if(n<m) resize(m);
for(int i=0;i<m;i++)
(*this)[i]=msub((*this)[i],p[i]);
return *this;
}
DEF_OP(*)
{
int n=size(),m=p.size(),sz=n+m-1;
if(!n || !m) return clear(),*this;
resize(sz);
if(NTT_CHECK(n,m))
{
MCPY(c1,data(),n);
MSET(c2,0,sz);
for(int i=0;i<n;i++)
for(int j=0;j<m;j++)
c2[i+j]=madd(c2[i+j],mmul(c1[i],p[j]));
MCPY(data(),c2,sz);
}
else if(this==addressof(p))
{
int nn=EXTEND(sz);
MCPY(c1,data(),n);
MSET(c1+n,0,nn-n);
DIT(c1,nn);
for(int i=0;i<nn;i++) c1[i]=mmul(c1[i],c1[i]);
DIF(c1,nn);
MCPY(data(),c1,sz);
}
else
{
int nn=EXTEND(sz);
MCPY(c1,data(),n),MCPY(c2,p.data(),m);
MSET(c1+n,0,nn-n),MSET(c2+m,0,nn-m);
DIT(c1,nn),DIT(c2,nn);
for(int i=0;i<nn;i++) c1[i]=mmul(c1[i],c2[i]);
DIF(c1,nn);
MCPY(data(),c1,sz);
}
return *this;
}
DEF_OP(/) { return (*this)*=p.inv(); }
DEF_OP(%) { return (*this)=divr(*this,p).second; }
#undef DEF_OP
Polynomial &operator *=(int k)
{ for(auto &i: *this) i=mmul(i,k); return *this; }
friend Polynomial operator *(const Polynomial &p,int k)
{ return Polynomial(p)*=k; }
friend Polynomial operator *(int k,const Polynomial &p)
{ return Polynomial(p)*=k; }
friend Polynomial derivative(const Polynomial &p)
{
int sz=p.size();
Polynomial q(sz-1);
for(int i=1;i<sz;i++) q[i-1]=mmul(p[i],i);
return q;
}
friend Polynomial integral(const Polynomial &p)
{
int sz=p.size();
Polynomial q(sz+1);
for(int i=1;i<sz;i++) q[i+1]=mdiv(p[i],i+1);
return q;
}
Polynomial inv()const
{
if(empty() || front()==0) throw runtime_error("[x^0]f(x)=0, f(x)^-1 doesn't exist.\n");
int sz=size(),nn=1<<(__lg((sz<<1)-1)+1);
Polynomial q(nn);
__polyinv(data(),q.data(),sz);
return q.resize(sz),q;
}
friend Polynomial ln(const Polynomial &p)
{
if(p.empty() || p[0]!=1) throw runtime_error("[x^0]f(x)!=1, ln(f(x)) doesn't exist.\n");
int sz=p.size(),nn=1<<(__lg((sz<<1)-1)+1);
Polynomial q(nn);
__polyln(p.data(),q.data(),sz);
return q.resize(sz),q;
}
friend Polynomial exp(const Polynomial &p)
{
if(p.empty()) return Polynomial{1};
if(p[0]!=0) throw runtime_error("[x^0]f(x)!=0, exp(f(x)) doesn't exist.\n");
static int c[MAXN];
int sz=p.size(),nn=1<<(__lg(sz-1)+1);
for(int i=0;i<sz;i++) c[i]=mmul(i,p[i]);
Polynomial q(nn);
__polyexp(c,q.data(),0,nn);
return q.resize(sz),q;
}
friend pair<Polynomial,Polynomial> divr(const Polynomial &f,const Polynomial &g)
{
if(f.size()<g.size()) return make_pair(Polynomial{0},f);
int n=f.size()-1,m=g.size()-1;
Polynomial fr(n+1),gr(m+1);
for(int i=0;i<=n;i++) fr[i]=f[n-i];
for(int i=0;i<=m;i++) gr[i]=g[m-i];
fr.resize(n-m+1),gr.resize(n-m+1),fr*=gr.inv();
fr.resize(n-m+1),reverse(fr.begin(),fr.end());
gr=f-fr*g,gr.resize(m);
return make_pair(fr,gr);
}
#undef NTT_CHECK
#undef EXTEND
#undef MCPY
#undef MSET
};
} // namespace ZPoly
using namespace Math::ZPoly;
int n;
string s1[100005],s2[100005];
#define Loop1(i,l,r) for(int i##0=(l);i##0<(r);i##0++)
#define Loop2(i,l,r) Loop1(i,l,r) for(int i##1=(l);i##1<(r);i##1++)
#define Loop3(i,l,r) Loop2(i,l,r) for(int i##2=(l);i##2<(r);i##2++)
#define Loop4(i,l,r) Loop3(i,l,r) for(int i##3=(l);i##3<(r);i##3++)
#define Loop5(i,l,r) Loop4(i,l,r) for(int i##4=(l);i##4<(r);i##4++)
int fac[100005],inv[100005];
inline int binom(int r,int c)
{ return r<c?0:mmul(fac[r],inv[c],inv[r-c]); }
inline void prepare()
{
fac[0]=1;
for(int i=1;i<=n;i++) fac[i]=mmul(fac[i-1],i);
inv[n]=qpow(fac[n],MOD-2);
for(int i=n;i>=1;i--) inv[i-1]=mmul(inv[i],i);
}
int sum[30][30][30][30][30];
int main()
{
qin>>n;
prepare();
for(int i=1;i<=n;i++) qin>>s1[i]>>s2[i];
Polynomial F(n+1),G(n+1);
for(int S=0;S<(1<<5);S++)
{
memset(sum,0,sizeof(sum));
for(int i=1;i<=n;i++)
{
int L[5]={},R[5]={};
bool ok=true;
for(int j=0;j<5;j++)
{
int c=s1[i][j]-'A';
if(s2[i][j]=='=') L[j]=R[j]=c;
else if(s2[i][j]=='>') L[j]=c+1,R[j]=25;
else if(s2[i][j]=='<') L[j]=0,R[j]=c-1;
R[j]-=(S>>j&1);
if(L[j]>R[j]) { ok=false;break; }
}
if(ok) Loop5(k,0,2)
{
int dt=((k0^k1^k2^k3^k4)?-1:1);
#define I(x) (k##x?R[x]+1:L[x])
sum[I(0)][I(1)][I(2)][I(3)][I(4)]+=dt;
#undef I
}
}
Loop5(i,0,26) sum[i0+1][i1][i2][i3][i4]+=sum[i0][i1][i2][i3][i4];
Loop5(i,0,26) sum[i0][i1+1][i2][i3][i4]+=sum[i0][i1][i2][i3][i4];
Loop5(i,0,26) sum[i0][i1][i2+1][i3][i4]+=sum[i0][i1][i2][i3][i4];
Loop5(i,0,26) sum[i0][i1][i2][i3+1][i4]+=sum[i0][i1][i2][i3][i4];
Loop5(i,0,26) sum[i0][i1][i2][i3][i4+1]+=sum[i0][i1][i2][i3][i4];
int op=__builtin_parity(S);
if(op) Loop5(i,0,26) F[sum[i0][i1][i2][i3][i4]]--;
else Loop5(i,0,26) F[sum[i0][i1][i2][i3][i4]]++;
}
Polynomial H(n+1);
for(int i=0;i<=n;i++)
{
if(F[i]<0) F[i]+=MOD;
F[i]=mmul(F[i],fac[i]);
H[n-i]=inv[i];
}
Polynomial tmp=F*H;
for(int i=0;i<=n;i++) G[i]=mmul(inv[i],tmp[i+n]);
G[0]=fac[n];
for(int i=1;i<=n;i++)
{
G[i]=mmul(G[i],fac[i],fac[n-i]);
if(i) qout<<mmul(inv[n-i],msub(G[i-1],G[i]))<<' ';
}
return 0;
}
详细
Test #1:
score: 100
Accepted
time: 1705ms
memory: 116688kb
input:
2 FAKER >>>>> CHOVY =====
output:
0 2
result:
ok 2 number(s): "0 2"
Test #2:
score: 0
Accepted
time: 1705ms
memory: 116636kb
input:
3 BVHUQ ><>>< YJCEQ <<><< SXXWZ >>==>
output:
1 4 0
result:
ok 3 number(s): "1 4 0"
Test #3:
score: 0
Accepted
time: 1816ms
memory: 117016kb
input:
8 IFSXA >><<= ZAKDA <>=>= UZVAA <<<>= MTACA <>>>= RJKVA <><<= IOXOA >=<<= MRMHA ><<<= BYFWA ==<>=
output:
0 16 108 396 816 720 0 0
result:
ok 8 numbers
Test #4:
score: 0
Accepted
time: 1658ms
memory: 117456kb
input:
8 BRKPR ><=<> VUCTO <<=<= PTCDB <<=>> PHMGV <><>< FGWHD >><>> SUSFH <<<<> IOLDD <<<<> WJPXX <><<<
output:
0 14 120 444 744 360 0 0
result:
ok 8 numbers
Test #5:
score: 0
Accepted
time: 1753ms
memory: 117436kb
input:
10 UAVZE =>=<= QVGJB >==>> ZLHUS >>>=> PGZOO ==<>< LAKYL =<=<= IMQAQ <>>== OBWGV >>=<> KQSOR <<>>= KGFVD >=<== RFDGJ <>><>
output:
2 66 48 0 0 0 0 0 0 0
result:
ok 10 numbers
Test #6:
score: 0
Accepted
time: 1826ms
memory: 116756kb
input:
10 GOMVB >>>>< DSPSI =><== UKTNW <<>=< SKNLH >=<>< TNYRS =<<>< QZHXW <==>> NLWVU ><=>= WHBAI ><>>= QXDIC <=<>> JBUFE =>==<
output:
0 86 32 0 0 0 0 0 0 0
result:
ok 10 numbers
Test #7:
score: 0
Accepted
time: 1782ms
memory: 117984kb
input:
10 SBDSY >>>=> NSYAP <><>= PIFGA >=>=> URDJY <>>>< EDLLY =><<> ZLWTD >>>>= OTTLU <><=< HYKKZ ===<< VRBUB =<><> AXKEY <==<>
output:
2 60 90 42 0 0 0 0 0 0
result:
ok 10 numbers
Test #8:
score: 0
Accepted
time: 1544ms
memory: 117436kb
input:
10 CPIAM ><>>> FZBGT ><>>> EUFKN ><>=> OWUOO <<<<> RJOOA <>><> VOMTV <<><= FZAYC ><><> GOQML ><><> WZGOV <<><= AAAAA <<<<<
output:
1 9 72 504 3024 15120 60480 181440 362880 362880
result:
ok 10 numbers
Test #9:
score: 0
Accepted
time: 1568ms
memory: 116356kb
input:
10 MYAFR <<>=< UUOJK <<><> AWYJM ><=<> FOSPK ><><> TUUIA <<><> OJAMS <>><< BUEGG ><>>> PTDUK <<><> SBLYM <>><> SFAAX >>>==
output:
0 14 128 816 4344 19320 65520 146160 161280 0
result:
ok 10 numbers
Test #10:
score: 0
Accepted
time: 1463ms
memory: 116600kb
input:
10 QJQVM <>>>< NYNHE ><>>< WSBQB <<>>> ONXCP <<<>< CKICH >>>>< CQHZL >>><< SPKWY <<<<< FAXVS >><<< RVBOC <<><> TRPLG =>>==
output:
0 28 250 1146 2856 3000 0 0 0 0
result:
ok 10 numbers
Test #11:
score: 0
Accepted
time: 1501ms
memory: 116412kb
input:
10 PDOHN <>>>< YIBBD <>>>< VKHGC <><>> KLJOB ><>>> DIUHJ >>=>< AGDCK ><>>> FFXBK >><>< CHIEL ><>>> HGPXS >>><< GFHRX =>>=<
output:
0 38 230 822 2040 3480 2880 0 0 0
result:
ok 10 numbers
Test #12:
score: 0
Accepted
time: 1503ms
memory: 116924kb
input:
10 BWSGL ><<>> XEXGK <><>> OUHKP <>>=< ZWXCT <><>< VWAOX ><><< KXAHA ><>>> VVFUL ><<<> RHBTD >>><> FHBMB >>=<> JKVSX >==>>
output:
0 32 242 930 2424 5160 5760 0 0 0
result:
ok 10 numbers
Test #13:
score: 0
Accepted
time: 1546ms
memory: 117924kb
input:
10 TFXCY >><<< ALEDI ><>>> YBXWE <><<> YVCHH <<>>< JCYDR ><=>< GNURG ><<<< QFLEM <>>>> JUUHR ><><< LMDZE ><><< TEDEE >>=><
output:
0 46 268 564 144 0 0 0 0 0
result:
ok 10 numbers
Test #14:
score: 0
Accepted
time: 1400ms
memory: 119836kb
input:
100000 BNLGH >>=== QXYTZ >>=>> NRBRX <==== HSKHN <<>>> WPOWG >===> UXFEU =><>> GROWO =><>> VPKSO <><>< WKUQA ===>> KGKHU >=>>> YSIHF >=>>< TOSXN <=>=< HTCKZ =>=>= LIDLA >==>= MNVDK <<<=> WHGMQ ><>>= BRCSN ><<>> YLOEF <<==> IBVUP <><== JHWHE <==>> CBSKF >==>= OLGHJ <>><< OUDND =>==< AMFMU =<=== SDUHG...
output:
12144 412636794 259958531 471914400 521830768 776198196 987954473 677670949 929976028 435141791 915818255 77808332 373696275 860004456 815590598 827302790 334750217 297638785 684154009 734333884 468372005 941077614 669579770 347535008 712117434 881704206 973579427 385468207 664289497 158009373 53637...
result:
ok 100000 numbers
Test #15:
score: 0
Accepted
time: 1428ms
memory: 119444kb
input:
100000 YZHMP ><<== WTMOD <>><< RPZJR >=>=< AAJNC ===>= DIHKN =><>< ANVCM <<><= GLDOE <><=> KSNER <>>== WRKUF =<<>< ESGBH =><=< QTAKH <>=>< JGOSQ ><<<= MYSQR =>>== KLRPC =<=>< QRMKD ===== FCBZE >>>=< BNXDB =><=> NNRQD >==== BPVWI ==<=< KXEYZ ===>< IJMLR ==<>< ZGHZX =<=>< NDLJA <=<<< NOVNI ><<<< JKSRM...
output:
12223 400459039 28986202 438885749 273376351 163951784 446281085 40534769 335228183 96236785 880355311 987490628 488442137 827131227 536678086 420675015 209408414 489894579 26613846 266498745 429205709 284226414 110233883 328154083 561800066 269995982 113946391 76900398 905441256 821243833 20626991 ...
result:
ok 100000 numbers
Test #16:
score: 0
Accepted
time: 1384ms
memory: 122844kb
input:
100000 UNCSX <<==< FOYMG =<==< WQXDL <=<>= RKJSP <=>>= LAXXT ><<== IEMZF ==><= DFSET >=><= CWRSU <<>== XBCYM ><=>< YFAWT >><=< HTRNJ <<<>> ZWKMT ===>= QDLYL <<=<< JOFQE ==<>> SWETU <<><> MYVMS =<>=< DGRNR =<>>< CNXBA <<<>= WDWYZ =<>>> KPNNU >=>=< QTGOB ==<>< JCHUK ><=== MLTEW =<>=> DTMMV =<=>= BSPZQ...
output:
12256 398686308 110275411 25618548 98398475 75789291 450067286 554959802 735917475 608870282 245681817 893103261 540261582 229311537 936917938 470322306 441117213 243813087 255324265 12696724 854288754 806520692 86012500 328564694 878537022 839751145 915142745 18140745 125518575 342802686 947890980 ...
result:
ok 100000 numbers
Test #17:
score: 0
Accepted
time: 1572ms
memory: 122668kb
input:
100000 FNVIO ><<=< ISCUB ><><> GQCGY ><>>< IIREF ><>>> LAWQL >><<< VDQNS <>><< ZDJDH <>>>= KAYMX >><<< KQWNL ><<<< MWVRW ><<<< FETOJ >=><< LEEOT >=><< ZGJPH <<><= VDPHC <>>>> VJRWA <<><> SCRPJ <>><< JBQCF >>>>> YWVGU <<<>< XGWNB <<<<> BTAWV ><><< RSMBD <<>>> KFBJX ><><< GPSZZ ><><< WMSOJ <<><< QLXDF...
output:
1 99999 17256472 629188600 994653422 292821735 911451747 83353224 313471011 405421054 346258483 928805941 779780412 28863579 29385371 263188556 923438024 483744622 815893954 359620773 119778186 363999506 944722253 608984733 934576938 654424456 495668524 619666932 294467430 975718913 171023568 124035...
result:
ok 100000 numbers
Test #18:
score: 0
Accepted
time: 1589ms
memory: 123220kb
input:
100000 LMPEM >>>>< TOLDK >>>>< JRYKL >=<>< WRTSU ==<=< TZPGR <<<>< BHJXB >><<> RABOA <>><> TXPJU ><>>< YVFBJ <<=>< NHATH >>><< CNZDF >><>= VHJJY >>>>< DOUAS >><>< GMMQA >><<> AMKPR >>>>< IKAET >>>>< MFRKW <><<< SSMLJ <<<<< YAMZX <><<< CCXTO >><<< QNAAD <>>>> XDHLM <>>>< BKGQR >>>>< UXXOM ><<>< ANGIJ...
output:
0 933308107 299928578 143136372 376251907 975068160 721593698 753716245 898914068 490205891 886874629 146781702 587935621 279193639 699856836 561537033 880030199 518890130 56000918 362873285 264834282 611906519 200388605 960190510 691501587 606436430 881745603 751535317 348317466 237651997 812697060...
result:
ok 100000 numbers
Test #19:
score: 0
Accepted
time: 1562ms
memory: 122580kb
input:
100000 GKZXQ >><<< KHLZG <><<> XOPSL <><<< BAIDJ >><<< ARFUW >=<<< SRWMZ ><<>< IXTCI ><<>> CUFJQ ><<<< POBFV ><>>= XZCXW <<<<< NYEWD ><><> CWOQS ><<>> VILXN >><<> AYMDC ><<<> MBCPI >>>>> CFRWC >><<> CXNGB ><<<> QNFZL ><><> PIGHX <><<< UUKUR <<<<< TUDZQ ><><> GILEV >><>= EGTTE >><<> RSKCL ><<>> LYCDJ...
output:
0 166507515 459156293 304072419 460723604 974806918 569354203 431542442 512958995 436405304 696400930 642914783 541251712 836652606 565059619 514610302 346747578 937985955 592127812 100884846 134893017 448171682 583736771 651700927 454623153 163064670 98018215 70402567 66918097 107584460 749714113 1...
result:
ok 100000 numbers
Test #20:
score: 0
Accepted
time: 1581ms
memory: 120060kb
input:
100000 BILQU ><><< EBKTE >><<> NKHCI <<>>> GKVMX >><<< GIWIC ><<<> MAJDU >>=>< YULTQ <<><< KUVIK ><<>> FHYGI >><>> JOFAK >=>>> WHJPB <=><> MOSVM >=<<> MDBWH <>><> VLLQC <<><> YQTQA <<<<> VZJNK <<><= TNHBE <>>>> OHYMP >><<> FQAOU ><><< LNWSW >><<< VBFVF <>><> OMQUC >><<> HCIUP >>><> MMZQH >><<> YJZWL...
output:
0 38401793 447045659 902564881 855486954 858682963 916341122 319325485 19812241 668526803 143151417 331148639 425925192 804865129 333676787 704794449 910479352 696417420 82040052 29985024 973090487 9476047 487918272 830170804 447737654 497561219 593481691 928465739 179957021 384533495 178611683 4766...
result:
ok 100000 numbers
Test #21:
score: 0
Accepted
time: 1605ms
memory: 119760kb
input:
100000 KSHEU ><><< LUTYV ><<<< MXQOI ><<>> NNMHY ><><< NZIPQ ><><< XMKMH <><>> DDFVV >>><< TMRIN <<><< YDSBB ==<>> GEIFO >><>< JRWVV ><<<< LXVTF ><<>> KFCQQ >>><< TVKCO ><<>< OHAGB >>><= PEVCO ><<>< LYCEB ><>>> NNNTN ><<>< EYYBZ ><<>< MPCCW ><>>< HTJKP ><><< LQQDT ><<>< WBTLI >><>= JRYTE ><<>> POITD...
output:
0 964094440 836003257 708459847 871957496 654344326 948234133 953935212 104979316 364845725 665219506 642340940 870161743 128194009 326925049 353939789 704216254 589740748 620536805 305640004 484148956 831968196 6769193 754098116 546127667 437282971 570088555 466566847 739533250 638265014 473500063 ...
result:
ok 100000 numbers
Test #22:
score: 0
Accepted
time: 1518ms
memory: 119928kb
input:
100000 IMBCQ <<>>> SLSQD <<<=> AEBES >>>>< HTEYK ><><> BRSCG ><<>> LDIEX <<><< BMEJV ><<>< LCKFQ <><>> IPIDE =<>=> IPSKI ><>>> IYLZC =<><> EOQKE ><>>> EAOOD >>=<> XGZUO <><<= RAVYT <><<< EVMYK ><><> GWXYP <<<<> UEVNV <><=< AQQOY ><><< NRJDS <<<>= HCNOG <><>> SULRW <<><< FXNYW ><><< NEJQZ <><=< LYWGI...
output:
0 666826810 289231209 635258529 546720275 543561692 384443596 63424828 510070428 21542771 129058559 151021435 187384460 692633074 922852987 414682697 568116010 769155697 91852932 392144234 495241700 671207649 143169942 467816836 792533501 612880812 687987052 299606463 754344297 139546526 882788940 4...
result:
ok 100000 numbers
Test #23:
score: 0
Accepted
time: 1530ms
memory: 123080kb
input:
100000 FNFJC >=>>> JBTYS >>=<< QVCYB <<><> TTGOO <>>>> CNNNE >=<<= HCQEM >>><< KTESX ><><< RLPVL <>><> CQADI ><><< NCZRF <><<> NTWBK <><>> OJUNY <>><< MHIDY >>>>< LFECL >>>>< ENNVS >=<<< YYXYK <<<<> BALXT >>><> JVXBJ ><<>< PTDBE ><>>> RCFNT <>><> ZPWFG <<=>> MSVDA ><<<> YJXSV <><<< DOVKD ><<>> DXSPO...
output:
0 93009970 219804152 844567284 891926848 279947250 689135271 860615218 13010915 929722006 847603974 484303861 136418364 827768488 46032089 429102220 810639676 270957951 53183964 293737892 477650398 234505706 517796197 156812171 966975447 945982240 982711670 726121039 576777787 297259995 372223803 55...
result:
ok 100000 numbers
Test #24:
score: 0
Accepted
time: 1562ms
memory: 119408kb
input:
100000 TPOQJ <<<<> XUUDN <<<>< YFAGQ <>>>< VWSWT <<<<> GITXC <><<< AYRDP ><>>< ZOXOZ <=>>= OQEEJ >>>>> LMMFK <>>>< YQMTZ <>=<< BAWDI >><>> TQUIE <><>> LQFOZ ><<<= XYJNB ><>>> ANPKA ><<>> XNAGO <>>>> AARCV >>>=> IMBOU <>><< ECQGU =><>< EWFDL <<<>> AFWTZ >>><< FKLNJ =><>< CEPMR >><<= DPBFC ><><> YIHUM...
output:
0 731820826 161250844 5585597 470134782 556060811 257099719 111798459 512206035 622445488 559050664 46611111 378388720 149248369 900197806 243792137 756773235 70170364 529089164 538199381 933788591 643539872 670120393 985010776 935645389 262590905 309790899 412774006 752230002 629492948 403174711 17...
result:
ok 100000 numbers
Test #25:
score: 0
Accepted
time: 1518ms
memory: 123060kb
input:
100000 QBQZL <><<> DLOQX ><<<< QFGSH >>>>> GXSNZ ><<<< RDDUT <>>=< WXVWY <<<=< VCCQL <>>=> YSTQR <<>=< DFUIN =><>< GEGVJ <>><< SDHHM >><>> HQFRU >><>< ZHMPJ <<=>> TVMYN ><><< RCXHI <><>> CIYCA >><<> KVATT <<>>< GUWBK <<<>> EUUKP ><<>> BHKJW >><<< XAIMU <>><> LBYQV >><>= FKLSD >>><> VUQIB <<<<> ATMAS...
output:
0 646701422 310542475 455998428 727671893 716649694 854302830 116778947 413591563 630505272 957959940 707160196 798797072 884778819 315551957 165825483 211983439 44654126 489986563 445117918 290339951 363429453 357974679 236558197 5060958 200582726 105877545 962523756 472161796 650269082 123320504 8...
result:
ok 100000 numbers
Test #26:
score: 0
Accepted
time: 1838ms
memory: 117240kb
input:
1 ZZZZZ =>=>>
output:
1
result:
ok 1 number(s): "1"