結果

問題 No.2798 Multiple Chain
ユーザー titiatitia
提出日時 2024-08-12 03:53:08
言語 Python3
(3.13.1 + numpy 2.2.1 + scipy 1.14.1)
結果
WA  
実行時間 -
コード長 765 bytes
コンパイル時間 208 ms
コンパイル使用メモリ 12,800 KB
実行使用メモリ 11,008 KB
最終ジャッジ日時 2024-08-12 03:53:24
合計ジャッジ時間 15,147 ms
ジャッジサーバーID
(参考情報)
judge5 / judge3
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 50 WA * 1
権限があれば一括ダウンロードができます

ソースコード

diff #

import sys
input = sys.stdin.readline

N=int(input())

D=[[] for i in range(65)]

r=round(N**(1/2))

if N%(r*r)==0:
    D[2].append(r)

for i in range(2,10**6+5):
    if N%i==0:
        count=0
        x=N
        while x%i==0:
            count+=1
            x//=i

        if count>=2:
            for j in range(2,count+1):
                D[j].append(i)

        rest=N//i

        r=round(rest**(1/2))

        if r!=1 and N%(r*r)==0:
            D[2].append(r)

for i in range(65):
    D[i]=list(set(D[i]))

ANS=[0]
def dfs(now,k):
    if k==1:
        ANS[0]+=1
        return

    for i in range(len(D[k])):
        if now%(D[k][i]**k)==0:
            dfs(now//(D[k][i]**k),k-1)

    dfs(now,k-1)

dfs(N,64)

print(ANS[0])
    
    
    
    
            
0