結果

問題 No.371 ぼく悪いプライムじゃないよ
ユーザー titia
提出日時 2025-09-04 03:22:03
言語 PyPy3
(7.3.15)
結果
WA  
実行時間 -
コード長 1,212 bytes
コンパイル時間 483 ms
コンパイル使用メモリ 82,300 KB
実行使用メモリ 76,920 KB
最終ジャッジ日時 2025-09-04 03:22:09
合計ジャッジ時間 5,968 ms
ジャッジサーバーID
(参考情報)
judge2 / judge5
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 4
other AC * 34 WA * 8
権限があれば一括ダウンロードができます

ソースコード

diff #

# x以下の素数の列挙,素因数分解,約数の列挙

x=10**6
    
import math 
L=math.floor(math.sqrt(x)) # 平方根を求める

Primelist=[i for i in range(x+1)]
Primelist[1]=0 # 1は素数でないので0にする.
 
for i in Primelist:
    if i>L:
        break
    if i==0:
        continue
    for j in range(2*i,x+1,i):
        Primelist[j]=0

Primes=[Primelist[j] for j in range(x+1) if Primelist[j]!=0]

L,H=map(int,input().split())

if L==H:
    print(H)

elif H-L<=100:
    ANS=[]
    MAX=0

    for i in range(L,H+1):
        for p in Primes:
            if i!=p and i%p==0:
                if MAX<=p:
                    MAX=p
                    ANS=i
                break

    print(ANS)

else:
    r=H**(1/2)

    for i in range(len(Primes)):
        if Primes[i]>=r:
            ind=i
            break

    ANS=0
    MAX=0

    for i in range(ind,-1,-1):
        flag=0
        for j in range(ind,len(Primes)):
            x=Primes[i]
            y=Primes[j]

            if x*y>H:
                break

            if L<=x*y<=H:
                flag=1
                ANS=x*y
                MAX=x

        if flag:
            break

    print(ANS)
                

            

0