結果
| 問題 | No.751 Frac #2 |
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2022-01-27 12:23:02 |
| 言語 | PyPy3 (7.3.17) |
| 結果 |
RE
|
| 実行時間 | - |
| コード長 | 1,322 bytes |
| 記録 | |
| コンパイル時間 | 179 ms |
| コンパイル使用メモリ | 82,428 KB |
| 実行使用メモリ | 67,700 KB |
| 最終ジャッジ日時 | 2024-12-24 22:04:20 |
| 合計ジャッジ時間 | 3,864 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge5 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 1 RE * 1 |
| other | AC * 5 WA * 4 RE * 27 |
ソースコード
from collections import defaultdict
def factorization(n):
arr = []
tmp = n
for i in range(2, int(-(-n**0.5//1))+1):
if tmp % i == 0:
cnt = 0
while tmp % i == 0:
cnt += 1
tmp //= i
arr.append([i, cnt])
if tmp != 1:
arr.append([tmp, 1])
if arr == []:
arr.append([n, 1])
return arr
n1 = int(input())
a = list(map(int, input().split()))
n2 = int(input())
b = list(map(int, input().split()))
top = a[0] * b[-1]
down = 1
for i in a:
down *= i
for i in b:
down *= i
down //= (a[0] * b[-1])
f_1 = factorization(top)
f_2 = factorization(down)
d_1 = defaultdict(int)
d_2 = defaultdict(int)
for i, j in f_1:
d_1[i] = j
for i, j in f_2:
d_2[i] = j
ans_top = defaultdict(int)
ans_down = defaultdict(int)
for k, v in d_1.items():
if d_2[k] == 0:
ans_top[k] = v
else:
ans_top[k] = v - min(v, d_2[k])
for k, v in d_2.items():
if d_2[k] == 0:
ans_down[k] = v
else:
ans_down[k] = v - min(v, d_1[k])
'''
print(top, down)
print(f_1, f_2)
print(d_1, d_2)
print(ans_top, ans_down)
'''
multi_top, multi_down = 1, 1
for k, v in ans_top.items():
multi_top *= k ** v
for k, v in ans_down.items():
multi_down *= k ** v
print(multi_top, multi_down)