結果
| 問題 |
No.990 N×Mマス計算(Kの倍数)
|
| コンテスト | |
| ユーザー |
tamato
|
| 提出日時 | 2020-02-14 22:50:34 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
RE
|
| 実行時間 | - |
| コード長 | 1,116 bytes |
| コンパイル時間 | 384 ms |
| コンパイル使用メモリ | 82,000 KB |
| 実行使用メモリ | 209,372 KB |
| 最終ジャッジ日時 | 2024-11-16 01:14:00 |
| 合計ジャッジ時間 | 10,557 ms |
|
ジャッジサーバーID (参考情報) |
judge1 / judge2 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 2 |
| other | AC * 11 WA * 3 RE * 2 TLE * 3 |
ソースコード
def main():
import sys
from collections import defaultdict
from math import sqrt, gcd
input = sys.stdin.readline
N, M, K = map(int, input().split())
line = input().split()
op = line[0]
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]
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_num = {}
for d in div:
for b in B:
if b%d == 0:
if d not in div_num:
div_num[d] = 1
else:
div_num[d] += 1
for a in A:
d = K // gcd(a, K)
ans += div_num[d]
print(ans)
if __name__ == '__main__':
main()
tamato