結果
| 問題 |
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)