結果
問題 | No.1081 和の和 |
ユーザー | kurimupy |
提出日時 | 2020-06-19 21:23:33 |
言語 | Python3 (3.12.2 + numpy 1.26.4 + scipy 1.12.0) |
結果 |
AC
|
実行時間 | 30 ms / 2,000 ms |
コード長 | 839 bytes |
コンパイル時間 | 92 ms |
コンパイル使用メモリ | 12,672 KB |
実行使用メモリ | 10,880 KB |
最終ジャッジ日時 | 2024-07-03 13:38:52 |
合計ジャッジ時間 | 974 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge2 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 30 ms
10,752 KB |
testcase_01 | AC | 30 ms
10,880 KB |
testcase_02 | AC | 28 ms
10,752 KB |
testcase_03 | AC | 28 ms
10,880 KB |
testcase_04 | AC | 28 ms
10,752 KB |
testcase_05 | AC | 26 ms
10,880 KB |
testcase_06 | AC | 28 ms
10,752 KB |
testcase_07 | AC | 27 ms
10,752 KB |
testcase_08 | AC | 27 ms
10,752 KB |
testcase_09 | AC | 26 ms
10,752 KB |
testcase_10 | AC | 29 ms
10,752 KB |
ソースコード
#コンビネーションクラスの作成 class Data(): def __init__(self): self.power=1 self.rev=1 class Combi(): def __init__(self,N,mod): self.lists=[Data() for _ in range(N+1)] self.mod=mod for i in range(2,N+1): self.lists[i].power=((self.lists[i-1].power)*i)%self.mod self.lists[N].rev=pow(self.lists[N].power,self.mod-2,self.mod) for j in range(N,0,-1): self.lists[j-1].rev=((self.lists[j].rev)*j)%self.mod def combi(self,K,R): if K<R: return 0 else: return ((self.lists[K].power)*(self.lists[K-R].rev)*(self.lists[R].rev))%self.mod N=int(input()) A=list(map(int,input().split())) ans=0 mod=10**9+ 7 c=Combi(N-1,mod) for i in range(N): ans+=c.combi(N-1,i)*A[i] ans%=mod print(ans)