QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#404177 | #4890. 这是一道集训队胡策题 | Butanlishi | 100 ✓ | 186ms | 37760kb | C++14 | 2.3kb | 2024-05-03 15:05:02 | 2024-05-03 15:05:02 |
Judging History
answer
#include<bits/stdc++.h>
#define ll long long
#define rg int
#define ci const int
#define ls x<<1
#define rs x<<1|1
#define mid ((l+r)>>1)
#define ld long double
#define fo(i,l,r) for(int i=(l);i<=(r);++i)
#define fd(i,l,r) for(int i=(l);i>=(r);--i)
#define fu(i,l,r) for(int i=(l);i<(r);++i)
#define gcd __gcd
#define P(x) __builtin_popcountll(x)
using namespace std;
ci N=2e6+5,M=5e3+5,mod=998244353,_g=3,_ig=(mod+1)/3;
ll ksm(ll a,ll b=mod-2)
{
ll ans=1;
while(b)
{
if(b&1)ans=(ll)ans*a%mod;
a=(ll)a*a%mod,b>>=1;
}
return ans;
}
const ld eps=1e-10;
inline ll read(){ll u,f=1;char o;while((o=getchar())<48||o>57)if(o==45)f=-1;u=(o^48);while((o=getchar())>=48&&o<=57)u=(u<<1)+(u<<3)+(o^48);return u*f;}
void write(ll x){if(x<0)putchar(45),x=-x;if(x>9)write(x/10);putchar(x%10+48);}
mt19937 rad(chrono::steady_clock::now().time_since_epoch().count());
ll n,t[M],fac[M],ifac[M];
struct node
{
ll w,id;
}b[N];
char ch[M][M];
bitset<5005>a[M],qz[M],hz[M],fu;
bool cmp(node x,node y)
{
return x.w<y.w;
}
ll C(ll n,ll m)
{
if(n<m||m<0)return 0;
return fac[n]*ifac[m]%mod*ifac[n-m]%mod;
}
int main()
{//freopen("1.in","r",stdin);
// freopen("b.in","r",stdin);
// freopen("b.out","w",stdout);
int T=1;
while(T--)
{
n=read();
fac[0]=1;
for(rg i=1;i<=n;++i)fac[i]=(ll)fac[i-1]*i%mod;
ifac[n]=ksm(fac[n],mod-2);
for(rg i=n;i>=1;--i)ifac[i-1]=(ll)ifac[i]*i%mod;
fo(i,1,n)
{
scanf("%s",ch[i]+1);
}
fo(i,1,n)
{
b[i].id=i;
fo(j,1,n)
{
ch[i][j]-='0';
b[i].w+=ch[i][j];
}
t[b[i].w]++;
}
sort(b+1,b+n+1,cmp);
fo(i,1,n)fo(j,1,n)a[i][j]=ch[b[i].id][j];
fo(i,1,n)t[i]+=t[i-1],fu[i]=1;
fo(i,1,n)qz[i]=qz[i-1]|a[i];
fd(i,n,1)hz[i]=hz[i+1]|(fu^a[i]);
ll ans=0;
fo(i,0,n)
{
ll l=t[i-1]+1,r=t[i];
// cout<<i<<' '<<l<<' '<<r<<'\n';
if(!(qz[l-1]&hz[r+1]).count())
{
if(l<=r)
{
bool f=0;
fo(i,l,r-1)if(a[i]!=a[i+1])
{
f=1;
break;
}
if(!f&&(a[l]&qz[l-1])==qz[l-1]&&!(a[l]&hz[r+1]).count())
{
ans=(ans+ksm(2,r-l+1))%mod;//cout<<i<<' '<<ans<<'\n';
}
}
else
{
// cout<<hz[r+1].count()<<'\n';
ans=(ans+C(n-qz[l-1].count()-hz[r+1].count(),i-qz[l-1].count()))%mod;
// cout<<i<<' '<<ans<<'\n';
}
}
}
cout<<ans<<'\n';
}
return 0;
}
这程序好像有点Bug,我给组数据试试?
詳細信息
Subtask #1:
score: 5
Accepted
Test #1:
score: 5
Accepted
time: 1ms
memory: 3616kb
input:
10 0000000000 0101111001 0101111001 0101111001 0101111001 0101111001 0101111001 0101111001 0101111001 0101111001
output:
591
result:
ok 1 number(s): "591"
Test #2:
score: 5
Accepted
time: 1ms
memory: 3700kb
input:
10 0000000000 0001100000 0001111111 0001111111 0001100000 0001111111 0001110100 0001110100 0001110100 0001110100
output:
47
result:
ok 1 number(s): "47"
Test #3:
score: 5
Accepted
time: 0ms
memory: 3824kb
input:
10 1000000000 1010000000 1010000000 1010111111 1010100111 1010100111 1010100111 1010100100 1010100100 1010100110
output:
30
result:
ok 1 number(s): "30"
Test #4:
score: 5
Accepted
time: 1ms
memory: 3952kb
input:
10 0000110001 0101100000 0100001111 1011000001 0011010000 1010011111 1000111100 1110111101 1000101100 1000110100
output:
2
result:
ok 1 number(s): "2"
Test #5:
score: 5
Accepted
time: 1ms
memory: 3936kb
input:
10 1000010100 1100001111 1111010111 1010000001 1000110111 0100001001 1000111110 0110100010 1010100010 1010110111
output:
2
result:
ok 1 number(s): "2"
Test #6:
score: 5
Accepted
time: 0ms
memory: 3828kb
input:
10 1011001000 1011111011 0111010011 0011110000 0000011100 0101000000 1001100000 1111010011 1110111101 1100010101
output:
2
result:
ok 1 number(s): "2"
Subtask #2:
score: 15
Accepted
Test #7:
score: 15
Accepted
time: 1ms
memory: 4008kb
input:
20 11110010101111111000 01000101111110100000 10110001010110111101 10111111011011110101 10110101011010111101 00010100011011001011 01111111001000101001 10101101011101011100 11011010110101011110 00010100101000001011 00001010100111101100 00100111010010101001 00000010010110110110 11011111100110111100 010...
output:
2
result:
ok 1 number(s): "2"
Test #8:
score: 15
Accepted
time: 0ms
memory: 3824kb
input:
20 01000110110000100100 00010110001100011000 11111000101101101010 10010001100000010100 01101101000000111100 10010111110101011101 00000101010000000110 00001100101111111110 11111110111001101001 00010000001000101011 00010010110110110011 01011011110010011110 01000101111111011101 00010111001101001110 101...
output:
2
result:
ok 1 number(s): "2"
Test #9:
score: 15
Accepted
time: 1ms
memory: 3780kb
input:
20 00000000000000000000 10011101011010000010 10011101011010000010 10011101011010000010 10011101011010000010 10011101011010000010 10011101011010000010 10011101011010000010 10011101011010000010 10011101011010000010 10011101011010000010 10011101011010000010 10011101011010000010 10011101011010000010 100...
output:
526847
result:
ok 1 number(s): "526847"
Test #10:
score: 15
Accepted
time: 1ms
memory: 3820kb
input:
20 00000000000000000000 11101100001001010011 11101100001001010011 11101100001001010011 11101100001001010011 11101100001001010011 11101100001001010011 11101100001001010011 11101100001001010011 11101100001001010011 11101100001001010011 11101100001001010011 11101100001001010011 11101100001001010011 111...
output:
526335
result:
ok 1 number(s): "526335"
Test #11:
score: 15
Accepted
time: 1ms
memory: 3988kb
input:
20 10000000000000000000 11111000110000000000 11111000110000000000 11111000111111111111 11111000111111111111 11111000111111111111 11111000110000000000 11111000111111111111 11111000110000000000 11111000111111111111 11111000111111111111 11111000111010011011 11111000111010011011 11111000111010011011 111...
output:
740
result:
ok 1 number(s): "740"
Test #12:
score: 15
Accepted
time: 1ms
memory: 3688kb
input:
20 10000000000000000000 11110100100000000000 11110100101111111111 11110100100000000000 11110100100000000000 11110100100000000000 11110100101111111111 11110100100000000000 11110100101111111111 11110100101111111111 11110100100000000000 11110100100010000000 11110100100010000000 11110100100010000000 111...
output:
1150
result:
ok 1 number(s): "1150"
Test #13:
score: 15
Accepted
time: 1ms
memory: 3756kb
input:
20 11111111111111111111 10100111111111111111 10100100000000000000 10100100000000000000 10100111111111111111 10100100000000000000 10100100000000000000 10100111001100101111 10100111001100101111 10100111001100100000 10100111001100101111 10100111001100100000 10100111001100100000 10100111001100101111 101...
output:
189
result:
ok 1 number(s): "189"
Subtask #3:
score: 40
Accepted
Test #14:
score: 40
Accepted
time: 2ms
memory: 5768kb
input:
300 01110011110110110011100111010000101110110001000111111011100101101101101011110101110100110110001110111010101011111010010101001000100011001110110100110000111001011011100000011100000000000001101000010110110000110001110000010110100010110110111000110000100101110011111010001100110111001010000100110110...
output:
2
result:
ok 1 number(s): "2"
Test #15:
score: 40
Accepted
time: 2ms
memory: 5616kb
input:
300 00101101101001110001110111101010000101010101100001110010001101001011011110111000110110101101111100010010011111010011101011110001011011111110001110100110101010100111001110001100111011010110010010111101001001101000000000011101011000111100101000101110111011001111111000111000100111100110101001011101...
output:
2
result:
ok 1 number(s): "2"
Test #16:
score: 40
Accepted
time: 2ms
memory: 5548kb
input:
300 00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000...
output:
936335109
result:
ok 1 number(s): "936335109"
Test #17:
score: 40
Accepted
time: 2ms
memory: 5600kb
input:
300 10000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000...
output:
124904823
result:
ok 1 number(s): "124904823"
Test #18:
score: 40
Accepted
time: 2ms
memory: 5544kb
input:
300 11111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...
output:
923149686
result:
ok 1 number(s): "923149686"
Test #19:
score: 40
Accepted
time: 2ms
memory: 5424kb
input:
300 01111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...
output:
254929271
result:
ok 1 number(s): "254929271"
Test #20:
score: 40
Accepted
time: 0ms
memory: 5392kb
input:
300 11111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...
output:
12177
result:
ok 1 number(s): "12177"
Subtask #4:
score: 5
Accepted
Test #21:
score: 5
Accepted
time: 186ms
memory: 37580kb
input:
5000 0000111111000001000100111100110001110111011000101000110111100011111110110011101001111001111101010001111101110011110101010011010010000000001111000111101111010010110100000110111101100000010111111110001001010100101110100010100000011100000101011011101010011111101011000110001001011010000010000101111...
output:
2
result:
ok 1 number(s): "2"
Test #22:
score: 5
Accepted
time: 178ms
memory: 37632kb
input:
5000 0010011001001111110110000001101010000101010111000001101101011100001001011101010000001111010001101001111000101001011011001000111110010001111011011101010000110000010100010110011010000110111110111100110100001010110010001011010010001001101110000000111110111111000110000011010011100001110011111010001...
output:
2
result:
ok 1 number(s): "2"
Test #23:
score: 5
Accepted
time: 174ms
memory: 37760kb
input:
5000 1100111111010100100110101001011111001111000111111010110110010101011010010001111010101001101110111111100100101111010111001111100001100101111111000010100011000110100010010110111111100001100010000111101011110111100010010000001110011110001110110001000101111010110011111001111001011011110010101000000...
output:
2
result:
ok 1 number(s): "2"
Subtask #5:
score: 35
Accepted
Test #24:
score: 35
Accepted
time: 99ms
memory: 37452kb
input:
5000 0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000...
output:
828414647
result:
ok 1 number(s): "828414647"
Test #25:
score: 35
Accepted
time: 91ms
memory: 37588kb
input:
5000 0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000...
output:
16621460
result:
ok 1 number(s): "16621460"
Test #26:
score: 35
Accepted
time: 179ms
memory: 37472kb
input:
5000 1010110111100100001010010010100011000101011011111111101001100001101101011001001110101011110101001110010011110111101001011010010001100100111010100100000011101101000100010001011001101100000000000000011001100101111101110010111101000000010001000101110111100011100110101001001000001101111010001111010...
output:
2
result:
ok 1 number(s): "2"
Test #27:
score: 35
Accepted
time: 101ms
memory: 37520kb
input:
5000 1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...
output:
541497915
result:
ok 1 number(s): "541497915"
Test #28:
score: 35
Accepted
time: 113ms
memory: 37452kb
input:
5000 0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000...
output:
288388087
result:
ok 1 number(s): "288388087"
Test #29:
score: 35
Accepted
time: 109ms
memory: 37644kb
input:
5000 0111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...
output:
352199570
result:
ok 1 number(s): "352199570"
Test #30:
score: 35
Accepted
time: 112ms
memory: 37524kb
input:
5000 1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...
output:
410201481
result:
ok 1 number(s): "410201481"
Extra Test:
score: 0
Extra Test Passed