結果
| 問題 |
No.990 N×Mマス計算(Kの倍数)
|
| コンテスト | |
| ユーザー |
tamato
|
| 提出日時 | 2020-02-14 23:11:21 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
RE
|
| 実行時間 | - |
| コード長 | 1,195 bytes |
| コンパイル時間 | 305 ms |
| コンパイル使用メモリ | 82,204 KB |
| 実行使用メモリ | 95,276 KB |
| 最終ジャッジ日時 | 2024-11-16 01:27:16 |
| 合計ジャッジ時間 | 2,727 ms |
|
ジャッジサーバーID (参考情報) |
judge2 / judge4 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | RE * 2 |
| other | RE * 19 |
ソースコード
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())
input = sys.stdin.readline
line = input().split()
op = line[0]
B = list(map(int, line[1:]))
A = [0] * N
input = sys.stdin.buffer.readline
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_num = {}
for a in A:
d = K // gcd(a, K)
if d in div_num:
ans += div_num[d]
else:
div_num[d] = 0
for b in B:
if b % d == 0:
div_num[d] += 1
ans += div_num[d]
print(ans)
if __name__ == '__main__':
main()
tamato