結果

問題 No.1340 おーじ君をさがせ
ユーザー shinchanshinchan
提出日時 2020-09-28 18:51:48
言語 PyPy3
(7.3.15)
結果
WA  
実行時間 -
コード長 600 bytes
コンパイル時間 220 ms
コンパイル使用メモリ 81,920 KB
実行使用メモリ 77,132 KB
最終ジャッジ日時 2024-11-26 19:27:27
合計ジャッジ時間 4,691 ms
ジャッジサーバーID
(参考情報)
judge1 / judge2
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 38 ms
52,352 KB
testcase_01 WA -
testcase_02 AC 37 ms
51,968 KB
testcase_03 AC 37 ms
51,328 KB
testcase_04 AC 37 ms
51,968 KB
testcase_05 AC 37 ms
52,352 KB
testcase_06 AC 37 ms
51,584 KB
testcase_07 AC 37 ms
51,968 KB
testcase_08 AC 36 ms
51,968 KB
testcase_09 WA -
testcase_10 AC 48 ms
60,800 KB
testcase_11 WA -
testcase_12 AC 50 ms
61,440 KB
testcase_13 WA -
testcase_14 WA -
testcase_15 WA -
testcase_16 AC 49 ms
61,440 KB
testcase_17 WA -
testcase_18 WA -
testcase_19 WA -
testcase_20 AC 51 ms
61,440 KB
testcase_21 AC 56 ms
66,432 KB
testcase_22 AC 54 ms
65,152 KB
testcase_23 AC 54 ms
66,688 KB
testcase_24 AC 53 ms
63,488 KB
testcase_25 AC 53 ms
65,280 KB
testcase_26 AC 52 ms
64,256 KB
testcase_27 AC 52 ms
63,360 KB
testcase_28 AC 53 ms
65,280 KB
testcase_29 AC 51 ms
64,512 KB
testcase_30 AC 55 ms
66,816 KB
testcase_31 AC 56 ms
67,456 KB
testcase_32 AC 54 ms
66,576 KB
testcase_33 AC 52 ms
66,560 KB
testcase_34 AC 53 ms
66,816 KB
testcase_35 AC 58 ms
68,480 KB
testcase_36 WA -
testcase_37 AC 53 ms
70,144 KB
testcase_38 AC 65 ms
77,132 KB
testcase_39 WA -
testcase_40 WA -
testcase_41 WA -
testcase_42 AC 36 ms
52,096 KB
testcase_43 AC 36 ms
51,840 KB
testcase_44 WA -
testcase_45 WA -
testcase_46 WA -
testcase_47 WA -
testcase_48 WA -
testcase_49 WA -
testcase_50 WA -
testcase_51 WA -
testcase_52 AC 50 ms
61,312 KB
testcase_53 WA -
testcase_54 WA -
testcase_55 AC 52 ms
63,232 KB
testcase_56 AC 50 ms
63,232 KB
testcase_57 AC 49 ms
63,360 KB
testcase_58 AC 50 ms
64,128 KB
testcase_59 AC 46 ms
59,776 KB
testcase_60 AC 36 ms
51,328 KB
testcase_61 AC 48 ms
60,416 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

# 嘘解法

N, M, T, *nums = map(int, open(0).read().split())
G = set(zip(nums[::2], nums[1::2]))
M = len(G)

T_max = min(T, 100000//(M+1))

T0 = [-1] * N
T1 = [-1] * N
dp = [0] * N
dp[0] = 1
for t in range(T_max):
    newdp = [0] * N
    for frm, to in G:
        if dp[frm] and not newdp[to]:
            newdp[to] = 1
            T0[to], T1[to] = T1[to], t
    dp = newdp

ans = 0
for v in range(N):
    if T == T_max:
        ans += dp[v]
    else:
        t0, t1 = T0[v], T1[v]
        if t0 == -1:
            continue
        ans += (T-t1) % (t1-t0) == 0
if ans == 0:
    ans = -1
print(ans)
0