結果

問題 No.389 ロジックパズルの組み合わせ
ユーザー ntuda
提出日時 2025-06-29 20:11:21
言語 PyPy3
(7.3.15)
結果
AC  
実行時間 146 ms / 2,000 ms
コード長 491 bytes
コンパイル時間 421 ms
コンパイル使用メモリ 82,416 KB
実行使用メモリ 144,884 KB
最終ジャッジ日時 2025-06-29 20:11:31
合計ジャッジ時間 9,115 ms
ジャッジサーバーID
(参考情報)
judge1 / judge3
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
other AC * 99
権限があれば一括ダウンロードができます

ソースコード

diff #

MOD = 10 ** 9 + 7

M = int(input())
N = M + 1
fact = [1]*(N+1)
rfact = [1]*(N+1)
r = 1
for i in range(1, N+1):
    fact[i] = r = r * i % MOD
rfact[N] = r = pow(fact[N], -1, MOD)
for i in range(N, 0, -1):
    rfact[i-1] = r = r * i % MOD

# nCk (mod MOD) を求める
def comb(n, k):
    return fact[n] * rfact[k] * rfact[n-k] % MOD

H = list(map(int,input().split()))
K = len(H)
sumh = sum(H)
if sumh == 0:
    K = 0
if sumh + K -1 > M:
    print("NA")
    exit()
print(comb(M - sumh + 1,K))
0