結果
問題 |
No.990 N×Mマス計算(Kの倍数)
|
ユーザー |
|
提出日時 | 2020-02-21 01:38:48 |
言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
結果 |
WA
|
実行時間 | - |
コード長 | 1,013 bytes |
コンパイル時間 | 340 ms |
コンパイル使用メモリ | 12,672 KB |
実行使用メモリ | 44,508 KB |
最終ジャッジ日時 | 2024-11-16 03:15:24 |
合計ジャッジ時間 | 6,686 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 16 WA * 3 |
ソースコード
import collections def divisors(n): ret=[] for i in range(1,int(n**0.5)+1): if n%i==0: ret.append(i) if i!=n//i: ret.append(n//i) return ret def gcd(a,b): if b==0: return a return gcd(b,a%b) n,m,k=map(int,input().split()) tmp=list(map(str,input().split())) op=tmp[0] arr1=[int(tmp[i]) for i in range(1,m+1)] arr2=[int(input()) for i in range(n)] ans=0 if op=='+': dic=collections.defaultdict(int) for i in range(m): arr1[i]%=k for i in range(n): arr2[i]%=k dic[arr2[i]]+=1 for i in range(m): ans+=dic[k-arr1[i]] else: divs=divisors(k) l=len(divs) dic1=collections.defaultdict(int) dic2=collections.defaultdict(int) for i in range(m): dic1[gcd(k,arr1[i])]+=1 for i in range(n): dic2[gcd(k,arr2[i])]+=1 for i in range(l): for j in range(l): if divs[i]*divs[j]%k==0: ans+=dic1[divs[i]]*dic2[divs[j]] print(ans)