結果
| 問題 |
No.117 組み合わせの数
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2016-07-11 18:18:02 |
| 言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
| 結果 |
AC
|
| 実行時間 | 336 ms / 5,000 ms |
| コード長 | 1,504 bytes |
| コンパイル時間 | 573 ms |
| コンパイル使用メモリ | 72,576 KB |
| 実行使用メモリ | 34,560 KB |
| 最終ジャッジ日時 | 2024-10-13 11:23:26 |
| 合計ジャッジ時間 | 1,619 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge2 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 1 |
コンパイルメッセージ
main.cpp: In function 'int main()':
main.cpp:76:23: warning: 'ans' may be used uninitialized [-Wmaybe-uninitialized]
76 | printf("%d\n", ans);
| ~~~~~~^~~~~~~~~~~~~
main.cpp:63:22: note: 'ans' was declared here
63 | int t, n, k, ans;
| ^~~
ソースコード
#include <iostream>
#include <cstdio>
#include <vector>
#include <algorithm>
#include <utility>
using namespace std;
const int MOD = 1e9 + 7;
const int N_MAX = 2e6;
vector<long long> factorial;
vector<long long> inv_factorial;
void make_factorials() {
factorial.assign(N_MAX + 1, 1);
for (int i = 2; i <= N_MAX; i++) {
factorial[i] = factorial[i-1] * i % MOD;
}
int p2 = MOD - 2;
inv_factorial.assign(N_MAX + 1, 1);
for (int i = 2; i <= N_MAX; i++) {
long long tmp = factorial[i];
for (int j = 0; j <= 30; j++) {
if ((p2 >> j) & 1) {
inv_factorial[i] = inv_factorial[i] * tmp % MOD;
}
tmp = tmp * tmp % MOD;
}
}
// for (int i = 0; i <= 10; i++) {
// printf("%2d, %10lld, %10lld\n", i, factorial[i], inv_factorial[i]);
// }
}
int calc_p(int n, int k) {
if (n < k) {
return 0;
}
return factorial[n] * inv_factorial[n - k] % MOD;
}
int calc_c(int n, int k) {
if (n < k) {
return 0;
}
return factorial[n] * inv_factorial[k] % MOD * inv_factorial[n - k] % MOD;
}
int calc_h(int n, int k) {
if (n == 0 && k == 0) {
return 1;
}
return calc_c(n + k - 1, k);
}
int main() {
make_factorials();
int t, n, k, ans;
char c;
scanf("%d\n", &t);
for (int i = 0; i < t; i++) {
scanf("%c(%d,%d)\n", &c, &n, &k);
switch (c) {
case 'P': ans = calc_p(n, k); break;
case 'C': ans = calc_c(n, k); break;
case 'H': ans = calc_h(n, k); break;
default: break;
}
// printf("%d: %d%c%d = %d\n", i, n, c, k, ans);
printf("%d\n", ans);
}
return 0;
}