結果

問題 No.3204 Permuted Integer
ユーザー flippergo
提出日時 2025-08-02 19:41:46
言語 PyPy3
(7.3.15)
結果
AC  
実行時間 643 ms / 2,000 ms
コード長 672 bytes
コンパイル時間 250 ms
コンパイル使用メモリ 82,572 KB
実行使用メモリ 90,280 KB
最終ジャッジ日時 2025-08-02 19:42:00
合計ジャッジ時間 13,562 ms
ジャッジサーバーID
(参考情報)
judge2 / judge1
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 1
other AC * 26
権限があれば一括ダウンロードができます

ソースコード

diff #

C = {i:set() for i in range(1,11)}
D = {}
for i in range(1,10**9+1):
    j = i*i
    if j>10**9:break
    j = sorted(list(str(j)))
    n = j.count("0")
    j = j[n:]
    flag = False
    for k in range(n+1):
        if tuple(j) in C[len(j)]:
            flag = True
            break
        j = ["0"]+j
    if not flag:
        j = j[1:]
        C[len(j)].add(tuple(j))
        D[tuple(j)] = i*i
T = int(input())
for _ in range(T):
    N = str(int(input()))
    n = N.count("0")
    N = sorted(list(N))
    N = N[n:]
    ans = -1
    for i in range(n+1):
        if tuple(N) in C[len(N)]:
            ans = D[tuple(N)]
            break
        N = ["0"]+N
    print(ans)
0