QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#814205 | #9330. Series Sum | Invincible | AC ✓ | 90ms | 11764kb | C++23 | 2.1kb | 2024-12-14 15:57:20 | 2024-12-14 15:57:20 |
Judging History
answer
#include <cstdio>
#include <algorithm>
#include <cstring>
#include <iostream>
#include <vector>
#include <set>
#include <queue>
#include <map>
#include <ctime>
#include <random>
#include <cassert>
#include <numeric>
#include <cmath>
#include <bitset>
#include <ext/pb_ds/assoc_container.hpp>
#define pii pair<int, int>
#define fi first
#define se second
#define MP make_pair
#define ep emplace
#define eb emplace_back
//#define int long long
#define rep(i, j, k) for (int i = (j); i <= (k); i++)
#define per(i, j, k) for (int i = (j); i >= (k); i--)
typedef double db;
typedef long double ldb;
typedef long long ll;
//typedef __int128 lll;
typedef unsigned long long ull;
typedef unsigned int ui;
using namespace std;
using namespace __gnu_pbds;
bool Mbe;
//char buf[1<<20],*p1,*p2;
//#define getchar() (p1 == p2 && (p2 = (p1 = buf) + fread(buf,1,1<<20,stdin), p1 == p2) ? 0 : *p1++)
int read() {
int s = 0, f = 1;
char c = getchar();
while (c < '0' || c > '9') f ^= (c == '-'), c = getchar();
while (c >= '0' && c <= '9') s = s * 10 + c - '0', c = getchar();
return f ? s : -s;
}
template<typename T>void chkmax(T&x,const T&y){if(x<y)x=y;}
template<typename T>void chkmin(T&x,const T&y){if(x>y)x=y;}
const int N=1000005,mod=998244353,inv2=(mod+1)/2;
int fplus(int x,int y){return x+y>=mod?x+y-mod:x+y;}
void Fplus(int&x,int y){x=fplus(x,y);}
int fminus(int x,int y){return x>=y?x-y:x+mod-y;}
void Fminus(int&x,int y){x=fminus(x,y);}
int fpow(int x,int k=mod-2){
int res=1;
for(;k;k>>=1){
if(k&1)res=(ll)res*x%mod;
x=(ll)x*x%mod;
}
return res;
}
int k,p,fac[N],ifac[N],n;
int C(int x,int y){return (ll)fac[x]*ifac[y]%mod*ifac[x-y]%mod;}
bool Med;
signed main() {
fprintf(stderr,"%.3lfMb\n",(&Mbe-&Med)/1024./1024.);
fac[0]=1;
rep(i,1,N-1)fac[i]=(ll)fac[i-1]*i%mod;
ifac[N-1]=fpow(fac[N-1]);
per(i,N-1,1)ifac[i-1]=(ll)ifac[i]*i%mod;
for(int T=read();T--;){
n=(k=read())*(p=read());
int now=0,ans=0;
rep(i,k,n)((i-k)&1?Fminus:Fplus)(now,C(i,k));
rep(d,k,n){
Fplus(ans,(ll)fpow(C(d,k),p)*now%mod);
(((n-d)&1)?Fplus:Fminus)(now,C(n+1,d+1));
now=(ll)now*inv2%mod;
}
printf("%d\n",fplus(ans,ans));
}
return 0;
}
Details
Tip: Click on the bar to expand more detailed information
Test #1:
score: 100
Accepted
time: 11ms
memory: 11644kb
input:
3 2 3 1 10 9 6
output:
818 204495126 16726290
result:
ok 3 number(s): "818 204495126 16726290"
Test #2:
score: 0
Accepted
time: 7ms
memory: 11644kb
input:
3 10 1 1 3 1 2
output:
2 26 6
result:
ok 3 number(s): "2 26 6"
Test #3:
score: 0
Accepted
time: 41ms
memory: 11596kb
input:
2112 16 51 27 30 32 22 6 69 1 7 6 40 15 63 23 37 11 57 6 92 8 62 5 50 11 76 1 57 99 8 2 90 35 10 13 54 6 33 8 70 14 48 12 63 7 99 85 7 14 60 7 78 22 22 1 53 6 61 2 67 8 68 5 67 7 57 8 79 11 29 15 44 8 62 19 39 9 71 3 65 3 83 6 16 11 86 7 25 124 6 1 21 5 76 17 35 14 29 1 55 67 13 987 1 8 27 4 99 8 19...
output:
958728366 182850046 337462356 238321759 94586 688819126 880558546 673294800 592760052 772846256 555807947 834237048 258386591 443217990 83210442 741605708 687991731 380324156 884202426 190172937 130140451 931313604 659396498 344165836 434542961 111646504 6836992 571531367 631528990 880394933 1976309...
result:
ok 2112 numbers
Test #4:
score: 0
Accepted
time: 90ms
memory: 11696kb
input:
6 1 164257 7 10955 1 30358 1 198674 1 206507 1 323519
output:
450748134 285759990 479497879 856048370 75480834 220335166
result:
ok 6 numbers
Test #5:
score: 0
Accepted
time: 78ms
memory: 11576kb
input:
4 62 12597 13 15082 2 11295 1 330
output:
134578883 817592796 66930551 383110659
result:
ok 4 number(s): "134578883 817592796 66930551 383110659"
Test #6:
score: 0
Accepted
time: 35ms
memory: 11632kb
input:
1009 31 32 25 40 41 24 500 2 29 34 38 26 38 26 90 11 200 5 71 14 50 20 34 29 47 21 125 8 111 9 37 27 142 7 45 22 125 8 27 36 58 17 27 36 35 28 28 35 43 23 125 8 333 3 32 31 71 14 25 39 100 10 35 28 27 36 47 21 27 37 66 15 47 21 25 40 37 27 34 29 45 22 35 28 66 15 333 3 50 20 25 39 25 39 26 38 76 13 ...
output:
871402622 419577502 603695744 784359155 759347810 51557094 51557094 712633402 954410959 616922676 816335450 256771489 866916495 760989591 859187268 459975997 550880541 525468303 760989591 277034910 243040669 277034910 631662375 200080307 141253289 760989591 775322262 996562074 616922676 86443311 524...
result:
ok 1009 numbers
Test #7:
score: 0
Accepted
time: 37ms
memory: 11704kb
input:
208 139 31 117 45 41 41 267 35 82 16 3 45 181 41 1219 8 31 44 1528 5 235 4 222 10 269 26 827 2 870 7 16 23 263 25 11 26 660 15 129 41 141 11 64 36 100 49 122 50 276 27 44 11 128 24 217 37 335 14 24 49 237 39 418 18 48 35 94 33 375 16 4 47 121 39 95 12 858 7 304 31 370 21 182 33 194 15 55 6 202 13 24...
output:
851150545 222205624 161298067 690708886 622565881 900621090 661760377 251742611 60893316 648664643 49553591 112014667 919771321 587648714 771905571 833478149 713320155 677714356 137765434 3585171 981954406 488903479 513181593 874511965 16170849 442603529 950708093 985481603 369032829 887191778 69043...
result:
ok 208 numbers
Test #8:
score: 0
Accepted
time: 63ms
memory: 11648kb
input:
1 1000 1000
output:
783050993
result:
ok 1 number(s): "783050993"
Test #9:
score: 0
Accepted
time: 14ms
memory: 11704kb
input:
10 100 100 99 101 98 102 97 103 96 104 101 99 102 98 103 97 104 96 105 95
output:
745474847 348955190 781334174 938153402 358565847 695815461 196183578 379968206 129529953 29572094
result:
ok 10 numbers
Test #10:
score: 0
Accepted
time: 10ms
memory: 11764kb
input:
6 3 2 4 4 3 3 3 5 5 3 4 5
output:
126 124014359 32162 328827205 64386506 567277979
result:
ok 6 numbers
Test #11:
score: 0
Accepted
time: 50ms
memory: 11708kb
input:
10 100 1000 1000 100 250 400 400 250 25000 4 5 20000 10 10000 10000 10 20000 5 4 25000
output:
354756979 228119416 829496936 168882209 168334375 302715191 745862435 202616186 375396996 520541595
result:
ok 10 numbers
Test #12:
score: 0
Accepted
time: 11ms
memory: 11708kb
input:
10 7 7 5 8 10 4 13 2 2 15 3 9 8 8 6 9 5 3 4 10
output:
629286899 91930612 465722397 823378532 871380528 417689043 815208695 887739621 64386506 566247517
result:
ok 10 numbers