結果
問題 | No.2206 Popcount Sum 2 |
ユーザー | 沙耶花 |
提出日時 | 2023-02-03 22:31:13 |
言語 | C++17 (gcc 12.3.0 + boost 1.83.0) |
結果 |
AC
|
実行時間 | 1,260 ms / 4,000 ms |
コード長 | 1,567 bytes |
コンパイル時間 | 6,369 ms |
コンパイル使用メモリ | 266,328 KB |
実行使用メモリ | 18,588 KB |
最終ジャッジ日時 | 2023-09-15 18:37:12 |
合計ジャッジ時間 | 27,464 ms |
ジャッジサーバーID (参考情報) |
judge13 / judge11 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 467 ms
11,972 KB |
testcase_01 | AC | 464 ms
12,108 KB |
testcase_02 | AC | 467 ms
11,920 KB |
testcase_03 | AC | 470 ms
11,932 KB |
testcase_04 | AC | 468 ms
11,952 KB |
testcase_05 | AC | 1,252 ms
18,588 KB |
testcase_06 | AC | 1,260 ms
18,376 KB |
testcase_07 | AC | 1,247 ms
18,016 KB |
testcase_08 | AC | 1,259 ms
18,008 KB |
testcase_09 | AC | 1,255 ms
18,028 KB |
testcase_10 | AC | 1,244 ms
17,048 KB |
testcase_11 | AC | 1,260 ms
17,040 KB |
testcase_12 | AC | 1,248 ms
16,948 KB |
testcase_13 | AC | 1,245 ms
16,232 KB |
testcase_14 | AC | 1,245 ms
16,260 KB |
testcase_15 | AC | 1,240 ms
16,268 KB |
testcase_16 | AC | 1,260 ms
17,572 KB |
testcase_17 | AC | 1,252 ms
17,304 KB |
testcase_18 | AC | 1,255 ms
17,264 KB |
ソースコード
#include <stdio.h> #include <atcoder/all> #include <bits/stdc++.h> using namespace std; using namespace atcoder; using mint = modint998244353; #define rep(i,n) for (int i = 0; i < (n); ++i) #define Inf32 1000000001 #define Inf64 1000000000000000001 int sz = 500; int nm = 200005; struct combi{ deque<mint> kaijou; deque<mint> kaijou_; combi(int n){ kaijou.push_back(1); for(int i=1;i<=n;i++){ kaijou.push_back(kaijou[i-1]*i); } mint b=kaijou[n].inv(); kaijou_.push_front(b); for(int i=1;i<=n;i++){ int k=n+1-i; kaijou_.push_front(kaijou_[0]*k); } } mint combination(int n,int r){ if(r>n)return 0; mint a = kaijou[n]*kaijou_[r]; a *= kaijou_[n-r]; return a; } mint junretsu(int a,int b){ mint x = kaijou_[a]*kaijou_[b]; x *= kaijou[a+b]; return x; } mint catalan(int n){ return combination(2*n,n)/(n+1); } }; int main(){ int q; cin>>q; vector<int> n(q),m(q); vector<vector<int>> is(nm); rep(i,q){ cin>>n[i]>>m[i]; is[n[i]-1].push_back(i); } vector<mint> ans(q); vector<mint> cur((nm + sz - 1)/sz,1); combi C(500000); rep(i,nm){ //cout<<i<<endl; rep(j,is[i].size()){ int nn = n[is[i][j]],mm = m[is[i][j]]-1; int ind = mm / sz; mint cv = cur[ind]; for(int k=ind*sz+1;k<=mm;k++){ cv += C.combination(i,k); } ans[is[i][j]] = cv; } rep(j,cur.size()){ int r = j * sz; cur[j] *= 2; if(r <= i)cur[j] -= C.combination(i,r); } } //cout<<'a'<<endl; rep(i,q){ ans[i] *= mint(2).pow(n[i]) - 1; cout<<ans[i].val()<<endl; } return 0; }