結果
| 問題 |
No.990 N×Mマス計算(Kの倍数)
|
| コンテスト | |
| ユーザー |
kota_rits
|
| 提出日時 | 2020-02-15 03:52:36 |
| 言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
| 結果 |
AC
|
| 実行時間 | 725 ms / 2,000 ms |
| コード長 | 961 bytes |
| コンパイル時間 | 252 ms |
| コンパイル使用メモリ | 12,544 KB |
| 実行使用メモリ | 37,188 KB |
| 最終ジャッジ日時 | 2024-11-16 02:08:37 |
| 合計ジャッジ時間 | 4,418 ms |
|
ジャッジサーバーID (参考情報) |
judge1 / judge4 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 2 |
| other | AC * 19 |
ソースコード
from sys import stdin
from math import gcd
n,m,k = map(int,stdin.readline().rstrip().split())
li = list(map(str,stdin.readline().rstrip().split()))
op = li[0]
b = [int(li[i]) for i in range(1,m+1)]
a = [int(stdin.readline().rstrip()) for _ in range(n)]
point = 0
if op == "+":
dic = {}
for B in b:
if B%k in dic:
dic[B%k] += 1
else:
dic[B%k] = 1
for A in a:
if -A%k in dic:
point += dic[-A%k]
elif op == "*":
dic_A = {};dic_B = {}
for B in b:
gcd_B = gcd(B,k)
if gcd_B in dic_B:
dic_B[gcd_B] += 1
else:
dic_B[gcd_B] = 1
for A in a:
gcd_A = gcd(A,k)
if gcd_A in dic_A:
dic_A[gcd_A] += 1
else:
dic_A[gcd_A] = 1
for A_key,A_value in dic_A.items():
for B_key,B_value in dic_B.items():
if A_key*B_key%k == 0:
point += A_value*B_value
print(point)
kota_rits