結果
| 問題 | No.1629 Sorting Integers (SUM of M) |
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2023-07-08 01:10:04 |
| 言語 | PyPy3 (7.3.17) |
| 結果 |
AC
|
| 実行時間 | 92 ms / 2,000 ms |
| コード長 | 1,132 bytes |
| 記録 | |
| コンパイル時間 | 158 ms |
| コンパイル使用メモリ | 85,312 KB |
| 実行使用メモリ | 141,688 KB |
| 最終ジャッジ日時 | 2026-04-03 06:05:25 |
| 合計ジャッジ時間 | 5,724 ms |
|
ジャッジサーバーID (参考情報) |
judge2_1 / judge3_1 |
| 純コード判定待ち |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| 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)