QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#800934#5747. Persian Casinoucup-team2179#AC ✓14ms6872kbC++231.2kb2024-12-06 16:58:222024-12-06 16:58:23

Judging History

你现在查看的是最新测评结果

  • [2024-12-06 16:58:23]
  • 评测
  • 测评结果:AC
  • 用时:14ms
  • 内存:6872kb
  • [2024-12-06 16:58:22]
  • 提交

answer

#include<bits/stdc++.h>
#define int long long
#define db double
#define pii pair<int, int>
using namespace std;
const int maxn = 2e5 + 999, mod = 1e9 + 9;
int n, m, fac[maxn], ifac[maxn];
int ksm(int a, int b) {
    int res = 1;
    for (; b; b >>= 1, a = a * a % mod)
        if (b & 1) res = res * a % mod;
    return res;
}
void init() {
    fac[0] = 1;
    for (int i = 1; i <= maxn - 5; i++) fac[i] = fac[i - 1] * i % mod;
    ifac[maxn - 5] = ksm(fac[maxn - 5], mod - 2);
    for (int i = maxn - 5; i; i--) ifac[i - 1] = ifac[i] * i % mod;
}
int C(int n, int m) {
    if (n < m || m < 0) return 0;
    return fac[n] * ifac[m] % mod * ifac[n - m] % mod;
} 
void solve() {
    cin >> n >> m;
    if(m >= n) cout << ksm(2, n) << '\n';
    else {
        if(m <= 20 && ksm(2, m) < n - m){
            cout << "bankrupt\n";
            return ;
        }
        int ans = C(n, m);
        for(int i = 0; i < m; i++){
            ans += C(n, i);
            ans %= mod;
        }
        cout << ans << '\n';
    }
}
signed main() {
    ios::sync_with_stdio(0), cin.tie(0), cout.tie(0);
    int t = 1;
    cin >> t;
    init();
    while (t--)
        solve();
}

詳細信息

Test #1:

score: 100
Accepted
time: 3ms
memory: 6832kb

input:

4
2 1
4 1
3 2
57639 34614

output:

3
bankrupt
7
869788168

result:

ok 4 lines

Test #2:

score: 0
Accepted
time: 4ms
memory: 6824kb

input:

16460
131 83
137 14
140 28
174 145
87 27
56 11
144 67
88 47
154 59
152 138
100 65
71 43
172 142
113 113
87 68
101 52
179 71
60 51
26 18
97 19
147 111
119 57
124 30
130 37
129 77
177 152
179 84
82 21
162 55
152 2
168 23
139 34
131 101
111 89
179 69
144 30
84 50
150 101
32 24
104 41
137 37
82 59
138 1...

output:

861401790
827411823
937669544
814872401
564368688
774329757
382020028
327399098
136919945
13075099
706031307
579851898
54033422
857164590
919274229
886008600
422741550
229676734
66137152
898506279
95608855
78287335
89291935
599857760
378517272
779874547
58872199
492901833
640116450
bankrupt
73638239...

result:

ok 16460 lines

Test #3:

score: 0
Accepted
time: 14ms
memory: 6816kb

input:

100000
40029 5
1295 16
50862 5
67072 8
51451 4
57967 7
40886 20
13278 1
61885 12
24790 1
80316 2
8554 8
49717 6
82652 8
83139 5
87135 16
7419 8
91357 12
28565 12
80411 1
83723 1
17818 2
36799 20
86016 7
56546 3
92119 10
46290 1
14836 14
63748 1
72859 1
1668 12
99713 23
65337 24
77683 11
36461 2
7810...

output:

bankrupt
670796506
bankrupt
bankrupt
bankrupt
bankrupt
563300247
bankrupt
bankrupt
bankrupt
bankrupt
bankrupt
bankrupt
bankrupt
bankrupt
bankrupt
bankrupt
bankrupt
bankrupt
bankrupt
bankrupt
bankrupt
58529615
bankrupt
bankrupt
bankrupt
bankrupt
402044100
bankrupt
bankrupt
966828094
574753812
1719404...

result:

ok 100000 lines

Test #4:

score: 0
Accepted
time: 4ms
memory: 6820kb

input:

10000
75096 170
52393 157
89622 59
30784 62
92872 10
71076 154
733 160
35387 46
58568 63
96455 37
18043 226
53139 74
66996 90
79664 104
19958 1
84256 54
70524 16
34545 185
91082 181
99565 33
29893 51
87375 453
17413 44
49497 24
9097 67
65189 54
31306 364
85625 117
78290 229
28127 246
34479 59
70644 ...

output:

123012973
875845468
632703855
95015750
bankrupt
294404653
666342970
378538549
154403803
235173547
931628007
563122776
484321021
604232511
bankrupt
35019044
bankrupt
135516031
380981336
246620795
230550839
428361020
878134211
325732400
568531164
25359531
993250912
721937924
313157146
652991298
323782...

result:

ok 10000 lines

Test #5:

score: 0
Accepted
time: 7ms
memory: 6752kb

input:

1000
47644 712
39508 2080
91319 429
85730 193
89231 168
90852 1107
80931 692
44589 1165
61601 951
88695 1910
60519 2251
44003 68
77030 848
9349 3069
70121 21
16638 998
52117 1644
35530 640
30994 2206
86108 136
79242 750
45127 973
45839 2784
75135 1944
81954 937
59327 870
88337 2220
68653 1577
69409 ...

output:

930453873
75883117
911046536
472013732
180280496
362653358
53928715
633333766
652440509
995224796
2931116
590100866
104383855
559878529
608706300
604009562
429916
768495784
835540783
357216087
269067241
729123218
42603437
192775096
966704296
177874111
751921227
752055542
10274469
267675070
599206665...

result:

ok 1000 lines

Test #6:

score: 0
Accepted
time: 6ms
memory: 6748kb

input:

100
73012 3305
96125 11209
80415 981
63939 896
78591 572
56336 7393
48805 3620
98106 6138
64727 9348
63916 10568
64292 13149
88382 7715
41879 582
21638 610
83120 10061
53454 5082
27632 25421
52870 6535
90516 1420
42812 13578
97541 5117
84906 13475
1710 1307
48910 22710
22829 21047
91296 8404
70542 4...

output:

609843775
88816326
639435670
80570776
983663105
275010173
452376363
890900928
979304130
501376054
397915490
642590560
547709565
503383640
850756857
619748066
265186543
374265426
778903446
698174635
47535239
271317915
464149816
828005243
552044237
966214572
996884359
406405556
958845890
896103374
996...

result:

ok 100 lines

Test #7:

score: 0
Accepted
time: 2ms
memory: 6804kb

input:

10
40291 55418
12041 7125
7314 16703
90831 100000
90856 73839
11469 15141
87559 73280
88535 15862
29541 58157
26050 53699

output:

664977345
465309497
968207886
129578339
293314678
308264056
381859983
629103736
434828827
743903142

result:

ok 10 lines

Test #8:

score: 0
Accepted
time: 0ms
memory: 6756kb

input:

173
2063 11
4105 12
32781 15
4113 12
16399 14
12 3
2059 11
3 2
16393 14
16400 14
8205 13
8209 13
520 9
2055 11
6 2
263 8
2058 11
1032 10
4104 12
130 7
72 6
1033 10
25 4
7 2
18 4
8202 13
3 1
73 6
65552 16
37 5
16396 14
131 7
1031 10
33 5
4112 12
7 3
2056 11
138 7
266 8
2061 11
16401 14
65557 16
65551...

output:

bankrupt
949628669
624456594
bankrupt
bankrupt
bankrupt
426743064
7
927956650
bankrupt
359324602
bankrupt
218127803
536465394
22
679550581
232414418
902513052
774286852
898963933
bankrupt
238097362
bankrupt
bankrupt
4048
997045147
4
bankrupt
182966799
510416
935626712
160344802
15888867
284274
bankr...

result:

ok 173 lines

Test #9:

score: 0
Accepted
time: 3ms
memory: 6872kb

input:

1
1 1

output:

2

result:

ok single line: '2'