結果
| 問題 |
No.1629 Sorting Integers (SUM of M)
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2023-07-08 01:10:04 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
AC
|
| 実行時間 | 137 ms / 2,000 ms |
| コード長 | 1,132 bytes |
| コンパイル時間 | 216 ms |
| コンパイル使用メモリ | 82,456 KB |
| 実行使用メモリ | 136,704 KB |
| 最終ジャッジ日時 | 2024-07-21 21:29:52 |
| 合計ジャッジ時間 | 3,229 ms |
|
ジャッジサーバーID (参考情報) |
judge4 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 4 |
| other | AC * 14 |
ソースコード
class NCK:
'''
最大値 :N
mod
'''
def __init__(self,N,mod):
self.mod = mod
self.N = N
self.factmod = [1,1]
for i in range(2,self.N+1):
self.factmod.append((self.factmod[-1]*i)%self.mod)
self.inv = [0,1]
for i in range(2, N + 1):
self.inv.append((-self.inv[self.mod % i] * (self.mod // i)) % self.mod)
self.invfact = [1,1]
for i in range(2, N + 1):
self.invfact.append((self.invfact[-1]*self.inv[i])%self.mod)
def nCk(self,a,b):
if a < b:
return 0
return ((self.factmod[a]*self.invfact[b]%self.mod)*self.invfact[a-b])%self.mod
def invnCk(self,a,b):
return ((self.factmod[a-b]*self.invfact[a]%self.mod)*self.factmod[b])%self.mod
N = int(input())
lsc = list(map(int,input().split()))
sums = sum([(i+1)*lsc[i] for i in range(9)])
mod = 10**9+7
ans = 0
ii = 1
nck = NCK(3*10**5,mod)
nn = nck.factmod[N-1]
for i in range(9):
nn *= nck.invfact[lsc[i]]
nn %= mod
for i in range(N):
ans += ii*sums*nn
ii *= 10
ans %= mod
ii %= mod
print(ans)