QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#111519 | #4435. Median | Dualqwq | AC ✓ | 617ms | 145756kb | C++14 | 5.5kb | 2023-06-07 14:56:33 | 2023-06-07 14:56:37 |
Judging History
answer
#include <bits/stdc++.h>
using namespace std;
const int N = 6600,M = 35,P = 1e9 + 7;
inline void Plus(int &x,const int &y) { x += y;if(x >= P) x -= P;}
inline int Add(const int &x,const int &y) { return (x + y >= P) ? (x + y - P) : (x + y);}
inline int qpow(int a,int b) { int res = 1;while(b) {if(b&1) res = 1ll * res * a % P;a = 1ll * a * a % P;b >>= 1;} return res;}
int n,m,q;
int a[N],vals[N],len;
inline int compute(int x,int y,int t) { return 1ll * qpow(t,x) * qpow(m - 1 - t,y) % P;}
namespace Comb{
int vals[M][M][M << 1]; // t^x(m - 1 - t) ^ y
int fac[M + M],ifac[M + M];
inline void prework(int m)
{
for(int x = 0;x <= m;x++)
for(int y = 0;y <= m;y++)
for(int i = 0;i <= x + y + 3;i++)
{
vals[x][y][i] = compute(x,y,i);
if(i) Plus(vals[x][y][i],vals[x][y][i - 1]);
}
fac[0] = 1;
for(int i = 1;i <= m + m;i++) fac[i] = 1ll * fac[i - 1] * i % P;
for(int i = 0;i <= m + m;i++) ifac[i] = qpow(fac[i],P - 2);
}
inline int Lagrange(int x,int y,int t)
{
static int pre[M + M],suf[M + M];
int ans = 0,deg = x + y + 3;
if(t <= deg) return vals[x][y][t];
pre[0] = 1;
for(int i = 1;i <= deg;i++) pre[i] = 1ll * pre[i - 1] * Add(t,P - i) % P;
suf[deg + 1] = 1;
for(int i = deg;i >= 1;i--) suf[i] = 1ll * suf[i + 1] * Add(t,P - i) % P;
for(int i = 1;i <= deg;i++)
{
int tmp = 1ll * ifac[i - 1] * ifac[deg - i] % P;
tmp = 1ll * tmp * pre[i - 1] % P * suf[i + 1] % P;
if((deg-i)&1) tmp = P - tmp;
tmp = 1ll * tmp * vals[x][y][i] % P;
Plus(ans,tmp);
}
return ans;
}
}
int dp[N * 3][M][M][3],tot,sze[N * 3];
int ch[N * 3][3],L[N * 3],R[N * 3];
inline int Turn(int x,int t)
{
if(x < t) return 0;
if(x > t) return 2;
return 1;
}
inline int GetMid(int x,int y,int z)
{
if(y > z) swap(y,z);
if(x > y) swap(x,y);
if(y > z) swap(y,z);
return y;
}
int build(int l,int r)
{
if(l > r) return 0;
int nd = ++tot;L[nd] = l;R[nd] = r;
if(l == r) return sze[nd] = (a[l] == -1),nd;
int tlen = (r - l + 1) / 3,m1 = ((r - l + 1) % 3) >= 1,m2 = (r - l + 1) % 3 >= 2;
int lmid = l + tlen + m1 - 1,rmid = lmid + 1 + tlen + m2 - 1;//[l,lmid] [lmid + 1,rmid] [rmid + 1,r]
ch[nd][0] = build(l,lmid);ch[nd][1] = build(lmid + 1,rmid);
ch[nd][2] = build(rmid + 1,r);
sze[nd] = sze[ch[nd][0]] + sze[ch[nd][1]] + sze[ch[nd][2]];
return nd;
}
void DP(int nd,int t)
{
if(!nd) return;
for(int x = 0;x <= sze[nd];x++)
for(int y = 0;x + y <= sze[nd];y++)
for(int a = 0;a < 3;a++) dp[nd][x][y][a] = 0;
if(L[nd] == R[nd])
{
if(a[L[nd]] != -1)
dp[nd][0][0][Turn(a[L[nd]],t)] = 1;
else
dp[nd][1][0][0] = dp[nd][0][1][2] = dp[nd][0][0][1] = 1;
return;
}
DP(ch[nd][0],t);DP(ch[nd][1],t);DP(ch[nd][2],t);
int *sons = ch[nd];
if(sons[2])
{
for(int s1 = 0;s1 <= 2;s1++)
for(int s2 = 0;s2 <= 2;s2++)
for(int s3 = 0;s3 <= 2;s3++)
{
int sres = GetMid(s1,s2,s3);
static int g[M][M];
for(int x = 0;x <= sze[sons[0]] + sze[sons[1]];x++)
for(int y = 0;y <= sze[sons[0]] + sze[sons[1]];y++)
g[x][y] = 0;
for(int x = 0;x <= sze[sons[0]];x++)
for(int y = 0;x + y <= sze[sons[0]];y++)
for(int a = 0;a <= sze[sons[1]];a++)
for(int b = 0;a + b <= sze[sons[1]];b++)
Plus(g[x + a][y + b],1ll * dp[sons[0]][x][y][s1] * dp[sons[1]][a][b][s2] % P);
for(int x = 0;x <= sze[sons[0]] + sze[sons[1]];x++)
for(int y = 0;x + y <= sze[sons[0]] + sze[sons[1]];y++)
for(int a = 0;a <= sze[sons[2]];a++)
for(int b = 0;a + b <= sze[sons[2]];b++)
Plus(dp[nd][x + a][y + b][sres],1ll * g[x][y] * dp[sons[2]][a][b][s3] % P);
}
}
else
{
for(int s1 = 0;s1 <= 2;s1++)
for(int s2 = 0;s2 <= 2;s2++)
for(int x = 0;x <= sze[sons[0]];x++)
for(int y = 0;x + y <= sze[sons[0]];y++)
for(int a = 0;a <= sze[sons[1]];a++)
for(int b = 0;a + b <= sze[sons[1]];b++)
Plus(dp[nd][x + a][y + b][min(s1,s2)],1ll * dp[sons[0]][x][y][s1] * dp[sons[1]][a][b][s2] % P);
}
}
int calc(int t)
{
tot = 0;
DP(1,t);
int ans = 0,s1 = 0,s2 = 0;
for(int i = 1;i <= n;i++) if(a[i] != -1) s1 += Turn(a[i],t) == 0,s2 += Turn(a[i],t) == 2;
for(int x = 0;x <= q;x++)
for(int y = 0;x + y <= q;y++)
{
if(s1 + x >= (n + 1) >> 1 || s2 + y >= (n >> 1) + 1)
continue;
Plus(ans,1ll * compute(x,y,t) * dp[1][x][y][1] % P);
}
return ans;
}
int Qsum(int l,int r)
{
if(l > r) return 0;
tot = 0;
DP(1,l);
int ans = 0,s1 = 0,s2 = 0;
for(int i = 1;i <= n;i++) if(a[i] != -1) s1 += Turn(a[i],l) == 0,s2 += Turn(a[i],l) == 2;
for(int x = 0;x <= q;x++)
for(int y = 0;x + y <= q;y++)
{
if(s1 + x >= (n + 1) >> 1 || s2 + y >= (n >> 1) + 1)
continue;
int coef = Add(Comb::Lagrange(x,y,r),P - Comb::Lagrange(x,y,l - 1));
Plus(ans,1ll * coef * dp[1][x][y][1] % P);
}
return ans;
}
void work()
{
cin >> n >> m;q = len = 0;
for(int i = 1;i <= n;i++)
{
cin >> a[i];
if(a[i] != -1) vals[++len] = a[i];
else ++q;
}
vals[++len] = 0;vals[++len] = m - 1;
sort(vals + 1,vals + len + 1);
int L = max(1,(len + 1 - q >> 1) - 1),R = min(len,(len + 1 + q >> 1) + 1);
int ans = 0;
Comb::prework(q);
tot = 0;
build(1,n);
for(int i = L;i <= R;i++)
if(i == L || vals[i] != vals[i - 1])
Plus(ans,calc(vals[i]));
for(int i = L;i < R;i++)
if(vals[i] + 1 <= vals[i + 1] - 1)
Plus(ans,Qsum(vals[i] + 1,vals[i + 1] - 1));
cout << ans << endl;
}
int main()
{
int T;
cin >> T;
while(T--) work();
return 0;
}
詳細信息
Test #1:
score: 100
Accepted
time: 261ms
memory: 9984kb
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: 210ms
memory: 8140kb
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: 596ms
memory: 145756kb
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: 617ms
memory: 145692kb
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: 149ms
memory: 6036kb
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: 14ms
memory: 5904kb
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