結果
問題 |
No.895 MESE
|
ユーザー |
![]() |
提出日時 | 2019-09-10 01:44:41 |
言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
結果 |
AC
|
実行時間 | 1,658 ms / 2,000 ms |
コード長 | 706 bytes |
コンパイル時間 | 154 ms |
コンパイル使用メモリ | 12,416 KB |
実行使用メモリ | 34,412 KB |
最終ジャッジ日時 | 2024-07-02 16:13:48 |
合計ジャッジ時間 | 24,061 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 26 |
ソースコード
#!/Users/fushishita/.pyenv/shims/python import sys MOD = 1000000007 fact = [1] rfact = [1] def mod_inverse(x): return pow(x, MOD - 2, MOD) def nCr(n, r): if r > n: return 0 ret = fact[n] ret = ret * rfact[r] % MOD ret = ret * rfact[n - r] % MOD return ret a, b, c = list(map(int, input().split())) n = a + b + c for i in range(1, n + 1): fact.append(fact[i - 1] * i % MOD) rfact.append(mod_inverse(fact[i])) ans = 0 for i in range(1, a + 1): x = a + b + c - i - 1 add = pow(2, x, MOD) - 1 add = add * nCr(x - 1, c - 1) % MOD * nCr(x - 1 - (c - 1), b - 1) % MOD ans = (ans + add) % MOD ans = (ans + MOD) % MOD print('{}\n'.format(ans), end='')