結果
| 問題 |
No.2017 Mod7 Parade
|
| コンテスト | |
| ユーザー |
tamato
|
| 提出日時 | 2022-07-22 21:57:09 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
AC
|
| 実行時間 | 215 ms / 2,000 ms |
| コード長 | 928 bytes |
| コンパイル時間 | 171 ms |
| コンパイル使用メモリ | 82,464 KB |
| 実行使用メモリ | 82,220 KB |
| 最終ジャッジ日時 | 2024-07-04 06:13:37 |
| 合計ジャッジ時間 | 4,090 ms |
|
ジャッジサーバーID (参考情報) |
judge4 / judge3 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 18 |
ソースコード
mod = 1000000007
def main():
import sys
input = sys.stdin.readline
N = int(input())
DL = []
for _ in range(N):
d, l = map(int, input().split())
DL.append((d, l % 6))
mod10 = [pow(10, i, 7) for i in range(6)]
dp = [[0] * 6 for _ in range(7)]
dp[0][0] = 1
for i in range(N - 1, -1, -1):
dp_new = [[0] * 6 for _ in range(7)]
d, l = DL[i]
if l:
dd = int(str(d) * l) % 7
else:
dd = 0
for j in range(7):
for k in range(6):
dp_new[j][k] = (dp_new[j][k] + dp[j][k]) % mod
dp_new[(j + dd * mod10[k]) % 7][(k + l) % 6] = (dp_new[(j + dd * mod10[k]) % 7][(k + l) % 6] + dp[j][k])%mod
dp = dp_new
ans = 0
for j in range(7):
for k in range(6):
ans = (ans + (j * dp[j][k]) % mod) % mod
print(ans)
if __name__ == '__main__':
main()
tamato