結果

問題 No.443 GCD of Permutation
ユーザー ebicochineal
提出日時 2016-11-12 00:30:21
言語 PyPy3
(7.3.15)
結果
RE  
実行時間 -
コード長 808 bytes
コンパイル時間 181 ms
コンパイル使用メモリ 82,228 KB
実行使用メモリ 383,744 KB
最終ジャッジ日時 2024-11-25 10:44:18
合計ジャッジ時間 10,293 ms
ジャッジサーバーID
(参考情報)
judge1 / judge3
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 4
other AC * 13 RE * 13 TLE * 2
権限があれば一括ダウンロードができます

ソースコード

diff #

#! /usr/bin/env python3

def f(n):
    l = []
    a, b = 0, 2
    while b * b <= n:
        if n % b == 0:
            n //= b
            l += [b]
        else:
            b += 1 + a
            a = 1
    if n > 1 : l += [n]
    return [1] + l

def g(a, b):
    r = []
    for i in a:
        if b % i == 0:
            r += [i]
            b //= i
    return r

gs = set([])
ga = 0
def p(s, ss):
    global ga
    if s == '':
        a = int(ss)
        gs.add(a)
        ga = a
    for i in set(s):
        p(s.replace(i, '', 1), ss+i)

def main():
    l = input()
    if len(set(l)) == 1:
        print(l)
        return
    
    s = set([])
    p(l,'')
    a = f(ga)
    for i in gs:
        a = g(a, i)
    ans = 1
    for i in a:
        ans *= i
    print(ans)

if __name__ == '__main__':
    main()
0