結果
問題 | No.990 N×Mマス計算(Kの倍数) |
ユーザー |
![]() |
提出日時 | 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)