結果
| 問題 |
No.990 N×Mマス計算(Kの倍数)
|
| コンテスト | |
| ユーザー |
tamato
|
| 提出日時 | 2020-02-14 23:47:50 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 1,253 bytes |
| コンパイル時間 | 378 ms |
| コンパイル使用メモリ | 82,128 KB |
| 実行使用メモリ | 114,800 KB |
| 最終ジャッジ日時 | 2024-11-16 01:50:00 |
| 合計ジャッジ時間 | 2,912 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge4 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 2 |
| other | AC * 14 WA * 5 |
ソースコード
def main():
import sys
from collections import defaultdict
from math import sqrt, gcd
input = sys.stdin.buffer.readline
N, M, K = map(int, input().split())
line = input().split()
op = line[0].decode()
B = list(map(int, line[1:]))
A = [0] * N
for i in range(N):
A[i] = int(input())
ans = 0
if op == '+':
dic_B = defaultdict(int)
for b in B:
dic_B[b%K] += 1
for a in A:
ans += dic_B[(K - a%K)%K]
else:
nmax = int(sqrt(K))
div = []
div_append = div.append
for d in range(1, nmax + 1):
if K % d == 0:
div_append(d)
div_append(K // d)
if nmax ** 2 == K:
div.pop()
div.sort()
dic_A = {d: 0 for d in div}
dic_B = {d: 0 for d in div}
for a in A:
dic_A[gcd(a, K)] += 1
for b in B:
dic_B[gcd(b, K)] += 1
for d in div:
for e in div:
if e < d and d%e == 0:
dic_A[e] += dic_A[d]
dic_B[e] += dic_A[d]
for d in dic_A:
ans += dic_A[d] * dic_B[K//d]
print(ans)
if __name__ == '__main__':
main()
tamato