結果
問題 |
No.990 N×Mマス計算(Kの倍数)
|
ユーザー |
|
提出日時 | 2020-02-21 01:41:26 |
言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
結果 |
AC
|
実行時間 | 1,124 ms / 2,000 ms |
コード長 | 1,078 bytes |
コンパイル時間 | 278 ms |
コンパイル使用メモリ | 12,672 KB |
実行使用メモリ | 44,480 KB |
最終ジャッジ日時 | 2024-11-16 03:15:56 |
合計ジャッジ時間 | 6,630 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 19 |
ソースコード
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): if arr1[i]!=0: ans+=dic[k-arr1[i]] else: ans+=dic[0] 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)