QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#54240 | #4435. Median | zhouhuanyi | AC ✓ | 211ms | 46560kb | C++11 | 5.3kb | 2022-10-07 16:58:35 | 2022-10-07 16:58:38 |
Judging History
answer
#include<iostream>
#include<cstdio>
#include<vector>
#include<algorithm>
#define N 13122
#define M 30
#define mod 1000000007
using namespace std;
int read()
{
char c=0;
int sum=0,f=1;
while (c!='-'&&(c<'0'||c>'9')) c=getchar();
if (c=='-') c=getchar(),f=-1;
while ('0'<=c&&c<='9') sum=sum*10+c-'0',c=getchar();
return sum*f;
}
int MD(int x)
{
return (x>=mod)?x-mod:x;
}
int MD2(int x)
{
return (x<0)?x+mod:x;
}
void Adder(int &x,int d)
{
x+=d;
if (x>=mod) x-=mod;
return;
}
void Adder2(int &x,int d)
{
x+=d;
if (x<0) x+=mod;
return;
}
int T,rt,leng,n,m,q,res1,res2,L,R,inv[N+1],C[M+1][M+1],S[M+1][M+1],a[N+1],sz[N+1],fa[N+1],F[M+1][M+1],dp[N+1][M+1][M+1][3],tong[N+1],length,sn[N+1][3],ans;
//0:> 1:>=
vector<int>v[N+1];
int get_mid(int x,int y,int z)
{
if (x>y) swap(x,y);
if (y>z) swap(y,z);
if (x>y) swap(x,y);
return y;
}
void push_up(int k)
{
if (sn[k][2])
{
sz[k]=sz[sn[k][0]]+sz[sn[k][1]]+sz[sn[k][2]];
for (int i=0;i<=sz[k];++i)
for (int i2=0;i+i2<=sz[k];++i2)
for (int j=0;j<=2;++j)
dp[k][i][i2][j]=0;
for (int s=0;s<=2;++s)
for (int s2=0;s2<=2;++s2)
for (int s3=0,s4;s3<=2;++s3)
{
s4=get_mid(s,s2,s3);
for (int i=0;i<=sz[sn[k][0]]+sz[sn[k][1]];++i)
for (int i2=0;i+i2<=sz[sn[k][0]]+sz[sn[k][1]];++i2)
F[i][i2]=0;
for (int i=0;i<=sz[sn[k][0]];++i)
for (int i2=0;i+i2<=sz[sn[k][0]];++i2)
for (int j=0;j<=sz[sn[k][1]];++j)
for (int j2=0;j+j2<=sz[sn[k][1]];++j2)
Adder(F[i+j][i2+j2],1ll*dp[sn[k][0]][i][i2][s]*dp[sn[k][1]][j][j2][s2]%mod);
for (int i=0;i<=sz[sn[k][0]]+sz[sn[k][1]];++i)
for (int i2=0;i+i2<=sz[sn[k][0]]+sz[sn[k][1]];++i2)
for (int j=0;j<=sz[sn[k][2]];++j)
for (int j2=0;j+j2<=sz[sn[k][2]];++j2)
Adder(dp[k][i+j][i2+j2][s4],1ll*F[i][i2]*dp[sn[k][2]][j][j2][s3]%mod);
}
}
else
{
sz[k]=sz[sn[k][0]]+sz[sn[k][1]];
for (int i=0;i<=sz[k];++i)
for (int i2=0;i+i2<=sz[k];++i2)
for (int j=0;j<=2;++j)
dp[k][i][i2][j]=0;
for (int i=0;i<=sz[sn[k][0]];++i)
for (int i2=0;i+i2<=sz[sn[k][0]];++i2)
for (int j=0;j<=sz[sn[k][1]];++j)
for (int j2=0;j+j2<=sz[sn[k][1]];++j2)
for (int s=0;s<=2;++s)
for (int t=0;t<=2;++t)
Adder(dp[k][i+j][i2+j2][min(s,t)],1ll*dp[sn[k][0]][i][i2][s]*dp[sn[k][1]][j][j2][t]%mod);
}
return;
}
int build(int l,int r)
{
if (l>r) return 0;
if (l==r)
{
for (int i=0;i<=1;++i)
for (int j=0;i+j<=1;++j)
for (int s=0;s<=2;++s)
dp[l][i][j][s]=0;
sz[l]=(a[l]==-1);
if (a[l]==-1) dp[l][1][0][0]=dp[l][0][0][1]=dp[l][0][1][2]=1;
else if (a[l]<L) dp[l][0][0][0]=1,res1++;
else dp[l][0][0][2]=1,res2++;
return l;
}
int nw=++leng,mid1=l+(r-l)/3,mid2=r-(r-l+1)/3;
sn[nw][0]=build(l,mid1),sn[nw][1]=build(mid1+1,mid2),sn[nw][2]=build(mid2+1,r),fa[sn[nw][0]]=fa[sn[nw][1]]=fa[sn[nw][2]]=nw,push_up(nw);
return nw;
}
void change(int x)
{
while (x!=rt) x=fa[x],push_up(x);
return;
}
int G(int x,int d)
{
int res=0;
for (int i=0,rst=x+1;i<=d;++i,rst=1ll*rst*(x+1-i)%mod) Adder(res,1ll*S[d][i]*rst%mod*inv[i+1]%mod);
return res;
}
int H(int x,int d,int d2)
{
int res=0;
for (int i=0,rst=1;i<=d2;++i,rst=1ll*rst*(m-1)%mod)
{
if (!((d2-i)&1)) Adder(res,1ll*C[d2][i]*rst%mod*G(x,d+d2-i)%mod);
else Adder2(res,-1ll*C[d2][i]*rst%mod*G(x,d+d2-i)%mod);
}
return res;
}
int main()
{
inv[1]=1;
for (int i=2;i<=N;++i) inv[i]=MD2(-1ll*(mod/i)*inv[mod%i]%mod);
for (int i=0;i<=M;++i) C[i][0]=1;
S[0][0]=1;
for (int i=1;i<=M;++i)
for (int j=1;j<=i;++j)
C[i][j]=MD(C[i-1][j-1]+C[i-1][j]),S[i][j]=MD(S[i-1][j-1]+1ll*S[i-1][j]*j%mod);
T=read();
while (T--)
{
leng=n=read(),m=read(),q=length=ans=res1=res2=0;
for (int i=1;i<=n;++i)
{
a[i]=read();
if (a[i]!=-1) tong[++length]=a[i];
else q++;
}
sort(tong+1,tong+length+1),L=tong[max(((n+1)>>1)-q,0)],R=(((n+1)>>1)<=length)?tong[(n+1)>>1]:m-1,length=unique(tong+1,tong+length+1)-tong-1,tong[length+1]=m,rt=build(1,n);
for (int i=1;i<=length;++i) v[i].clear();
for (int i=1;i<=n;++i)
if (a[i]!=-1)
v[lower_bound(tong+1,tong+length+1,a[i])-tong].push_back(i);
if (tong[1]&&tong[1]-1>=L)
{
for (int i=0;i<=q;++i)
for (int j=0;i+j<=q;++j)
if (i+res1<=((n+1)>>1)-1&&j+res2<=(n>>1))
Adder(ans,1ll*dp[rt][i][j][1]*H(tong[1]-1,i,j)%mod);
}
for (int i=1;i<=length;++i)
if (max(L,tong[i])<=min(R,tong[i+1]-1))
{
res2-=v[i].size();
for (int j=0;j<v[i].size();++j) dp[v[i][j]][0][0][1]=1,dp[v[i][j]][0][0][2]=0,change(v[i][j]);
for (int j=0;j<=q;++j)
for (int k=0,rst;j+k<=q;++k)
if (j+res1<=((n+1)>>1)-1&&k+res2<=(n>>1))
{
rst=1;
for (int t=1;t<=j;++t) rst=1ll*rst*tong[i]%mod;
for (int t=1;t<=k;++t) rst=1ll*rst*(m-1-tong[i])%mod;
Adder(ans,1ll*dp[rt][j][k][1]*rst%mod);
}
for (int j=0;j<v[i].size();++j) dp[v[i][j]][0][0][0]=1,dp[v[i][j]][0][0][1]=0,change(v[i][j]);
res1+=v[i].size();
if (tong[i]+1<tong[i+1])
{
for (int j=0;j<=q;++j)
for (int k=0;j+k<=q;++k)
if (j+res1<=((n+1)>>1)-1&&k+res2<=(n>>1))
Adder(ans,1ll*dp[rt][j][k][1]*MD2(H(tong[i+1]-1,j,k)-H(tong[i],j,k))%mod);
}
}
printf("%d\n",ans);
}
return 0;
}
Details
Tip: Click on the bar to expand more detailed information
Test #1:
score: 100
Accepted
time: 182ms
memory: 5660kb
input:
15 243 1000000000 -1 29468338 355773798 761105990 975183824 940954671 49695481 2420274 69788411 -1 979991492 3032467 17309120 35441759 57547446 984522064 963377808 941566026 -1 52327239 919801232 559983699 48206737 7562203 952424891 988395893 923140239 -1 55615681 965648038 20078303 41339546 5593795...
output:
427347483 209128659 983589908 929684141 872396735 569980709 741455941 192943067 612121803 34146211 875444781 600569018 28884930 324238308 377876598
result:
ok 15 lines
Test #2:
score: 0
Accepted
time: 156ms
memory: 6020kb
input:
15 109 999938037 405565317 -1 265405729 258333418 787620777 352728551 271622021 315692619 326238800 443453311 67954991 572715747 764474671 320422083 252154028 786346059 233338404 336168747 992018757 155728321 436420577 703657092 574311666 731177483 460540768 -1 391905366 -1 534827958 922051410 73872...
output:
377668707 0 0 0 365661712 370677619 198148861 848422689 261224933 938218359 272779059 0 0 562236065 690141617
result:
ok 15 lines
Test #3:
score: 0
Accepted
time: 211ms
memory: 46560kb
input:
3 6561 1000000000 -1 51139407 914701516 931073493 105684116 155600185 5661925 94556933 20025835 771662043 302285241 980022495 260394946 33063990 75206456 23184971 73368570 70153763 972308372 171291199 910475499 991568610 959088126 997112158 922329451 949815294 165121955 300374687 65027799 807619141 ...
output:
140944695 240690635 225600092
result:
ok 3 lines
Test #4:
score: 0
Accepted
time: 189ms
memory: 46424kb
input:
3 6561 1000000000 0 100 200 300 400 500 600 700 800 900 1000 1100 1200 1300 1400 1500 1600 1700 1800 1900 2000 2100 2200 2300 2400 2500 2600 2700 2800 2900 3000 3100 3200 3300 3400 3500 3600 3700 3800 3900 4000 4100 4200 4300 4400 4500 4600 4700 4800 4900 5000 5100 5200 5300 5400 5500 5600 5700 5800...
output:
689051971 927937858 455751710
result:
ok 3 lines
Test #5:
score: 0
Accepted
time: 78ms
memory: 4604kb
input:
100 81 171 156 78 67 75 1 65 122 49 88 -1 32 9 4 154 84 100 45 132 23 85 34 24 35 -1 72 98 165 21 159 -1 -1 71 159 -1 152 -1 17 -1 134 136 154 50 132 155 -1 36 86 92 137 48 158 37 61 77 32 24 23 132 155 60 148 21 15 64 2 145 64 63 73 135 72 86 66 104 85 -1 -1 95 149 103 14 81 156 -1 61 5 133 -1 86 7...
output:
687069270 160024926 790789527 278138648 302395944 372205785 36998337 783782379 179883845 111615383 407783287 220248459 973295348 143771036 31818629 23453226 708331566 431771328 999726644 680930187 646026473 188101635 281948387 173842834 355884695 343292049 411856409 595014896 736906788 230047003 606...
result:
ok 100 lines
Test #6:
score: 0
Accepted
time: 16ms
memory: 4768kb
input:
100 63 39 7 18 32 18 33 28 -1 3 13 26 28 12 6 -1 4 -1 35 20 0 -1 38 15 37 25 -1 29 7 36 4 12 24 24 37 30 19 31 26 -1 20 15 25 26 33 25 33 11 13 11 -1 22 17 38 23 9 26 24 31 12 29 -1 7 3 -1 50 100 0 2 4 6 8 10 12 14 16 18 20 22 24 26 28 30 32 34 36 38 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 61 63 65 67 69 71 7...
output:
0 876703841 4 55894 0 1347 8635 188779390 8635 9 760036864 8 198663832 0 657219 32620680 872125101 984122908 216 641336219 26181 1000 603986399 456321176 0 33326805 100 11 64 589249587 286031872 604 125 13 409741522 621852 859944816 117 141 1 990446051 9 36140 675563328 1 169 23145 1 1000 937 3523 2...
result:
ok 100 lines
Extra Test:
score: 0
Extra Test Passed