結果
| 問題 | 
                            No.751 Frac #2
                             | 
                    
| コンテスト | |
| ユーザー | 
                             | 
                    
| 提出日時 | 2022-01-27 12:23:02 | 
| 言語 | PyPy3  (7.3.15)  | 
                    
| 結果 | 
                             
                                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)