結果

問題 No.1140 EXPotentiaLLL!
ユーザー yuppe19 😺yuppe19 😺
提出日時 2020-08-01 10:13:39
言語 Python3
(3.12.2 + numpy 1.26.4 + scipy 1.12.0)
結果
AC  
実行時間 1,306 ms / 2,000 ms
コード長 543 bytes
コンパイル時間 104 ms
コンパイル使用メモリ 12,544 KB
実行使用メモリ 158,060 KB
最終ジャッジ日時 2024-07-07 18:33:16
合計ジャッジ時間 16,066 ms
ジャッジサーバーID
(参考情報)
judge5 / judge1
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 1,306 ms
133,416 KB
testcase_01 AC 1,115 ms
133,308 KB
testcase_02 AC 1,209 ms
133,036 KB
testcase_03 AC 982 ms
110,176 KB
testcase_04 AC 924 ms
95,220 KB
testcase_05 AC 1,107 ms
124,264 KB
testcase_06 AC 1,073 ms
119,820 KB
testcase_07 AC 1,217 ms
130,720 KB
testcase_08 AC 437 ms
48,808 KB
testcase_09 AC 463 ms
48,772 KB
testcase_10 AC 433 ms
48,516 KB
testcase_11 AC 439 ms
49,080 KB
testcase_12 AC 439 ms
158,060 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

#!/usr/bin/env python3
# †
import os
import numpy as np

if __name__ == '__main__':
    M = 5_000_006
    is_prime = np.full(M, True)
    is_prime[0] = is_prime[1] = False
    for p in range(2, int(np.sqrt(M))+1):
        if is_prime[p]:
            is_prime[p*p::p] = False

    dat = os.read(0, 14000010).decode().split('\n')
    N = int(dat[0])

    def f(a, p):
        if is_prime[p]:
            return [b'0', b'1'][a % p != 0]
        return b'-1'

    os.write(1, b'\n'.join(f(*map(int, dat[i+1].split())) for i in range(N)) + b'\n')
0