結果
問題 | No.1473 おでぶなおばけさん |
ユーザー | 小野寺健 |
提出日時 | 2021-04-26 14:54:52 |
言語 | Java21 (openjdk 21) |
結果 |
AC
|
実行時間 | 1,953 ms / 2,000 ms |
コード長 | 1,735 bytes |
コンパイル時間 | 5,228 ms |
コンパイル使用メモリ | 77,224 KB |
実行使用メモリ | 82,124 KB |
最終ジャッジ日時 | 2023-09-18 07:47:41 |
合計ジャッジ時間 | 60,543 ms |
ジャッジサーバーID (参考情報) |
judge13 / judge14 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 122 ms
55,720 KB |
testcase_01 | AC | 121 ms
55,960 KB |
testcase_02 | AC | 1,734 ms
82,124 KB |
testcase_03 | AC | 1,372 ms
79,640 KB |
testcase_04 | AC | 1,024 ms
71,232 KB |
testcase_05 | AC | 634 ms
65,512 KB |
testcase_06 | AC | 1,546 ms
79,928 KB |
testcase_07 | AC | 1,455 ms
80,060 KB |
testcase_08 | AC | 1,628 ms
81,664 KB |
testcase_09 | AC | 1,438 ms
81,832 KB |
testcase_10 | AC | 1,118 ms
71,460 KB |
testcase_11 | AC | 1,121 ms
71,852 KB |
testcase_12 | AC | 1,137 ms
71,884 KB |
testcase_13 | AC | 868 ms
68,996 KB |
testcase_14 | AC | 762 ms
67,340 KB |
testcase_15 | AC | 1,122 ms
71,100 KB |
testcase_16 | AC | 1,131 ms
71,564 KB |
testcase_17 | AC | 347 ms
60,264 KB |
testcase_18 | AC | 451 ms
60,400 KB |
testcase_19 | AC | 1,014 ms
68,736 KB |
testcase_20 | AC | 1,221 ms
76,472 KB |
testcase_21 | AC | 1,387 ms
71,244 KB |
testcase_22 | AC | 1,953 ms
78,796 KB |
testcase_23 | AC | 1,438 ms
78,712 KB |
testcase_24 | AC | 1,853 ms
76,408 KB |
testcase_25 | AC | 1,581 ms
78,900 KB |
testcase_26 | AC | 1,155 ms
78,948 KB |
testcase_27 | AC | 777 ms
67,260 KB |
testcase_28 | AC | 1,397 ms
81,472 KB |
testcase_29 | AC | 1,130 ms
71,460 KB |
testcase_30 | AC | 1,294 ms
76,192 KB |
testcase_31 | AC | 1,335 ms
80,900 KB |
testcase_32 | AC | 1,230 ms
78,740 KB |
testcase_33 | AC | 1,056 ms
75,984 KB |
testcase_34 | AC | 688 ms
69,264 KB |
testcase_35 | AC | 764 ms
69,084 KB |
testcase_36 | AC | 1,495 ms
70,624 KB |
testcase_37 | AC | 1,055 ms
76,392 KB |
testcase_38 | AC | 462 ms
60,856 KB |
testcase_39 | AC | 1,114 ms
71,508 KB |
testcase_40 | AC | 1,105 ms
71,512 KB |
testcase_41 | AC | 1,128 ms
70,560 KB |
testcase_42 | AC | 1,151 ms
71,152 KB |
testcase_43 | AC | 1,120 ms
79,732 KB |
testcase_44 | AC | 1,098 ms
79,308 KB |
testcase_45 | AC | 1,103 ms
79,016 KB |
testcase_46 | AC | 1,038 ms
75,948 KB |
testcase_47 | AC | 1,252 ms
79,356 KB |
testcase_48 | AC | 1,200 ms
77,772 KB |
ソースコード
package yukicoder; import java.util.Scanner; import java.util.List; import java.util.ArrayList; import java.util.Arrays; public class No1473_3 { private static class Q { int i; int d; public Q(int i, int d) { this.i = i; this.d = d; } } private static int n; private static List<List<Q>> V; public static void main(String[] args) { Scanner scan = new Scanner(System.in); n = scan.nextInt(); int m = scan.nextInt(); V = new ArrayList<List<Q>>(); for (int i = 0; i < n; i++) { V.add(new ArrayList<Q>()); } int[] w = new int[m+2]; int max = 0; int min = Integer.MAX_VALUE; for (int i=0; i < m; i++) { int s = scan.nextInt() - 1; int t = scan.nextInt() - 1; int d = scan.nextInt(); V.get(s).add(new Q(t, d)); V.get(t).add(new Q(s, d)); w[i+1] = d; max = Math.max(max, d); min = Math.min(min, d); } w[0] = min; w[m+1] = max; Arrays.sort(w); scan.close(); for (int i=0; i < n; i++) { V.get(i).sort((a,b) -> b.d - a.d); } Q l = new Q(0, 0), r = new Q(m+1, 0); while (r.i - l.i > 1) { int mid = (r.i + l.i) / 2; int c = bfs(w[mid]); if (c < 0) { r.i = mid; r.d = 0; } else { l.i = mid; l.d = c; } } System.out.println(String.format("%d %d", w[l.i],l.d)); } private static int bfs(int w) { int[] dist = new int[n]; Arrays.fill(dist, -1); List<Integer> que = new ArrayList<Integer>(); dist[0] = 0; que.add(0); while (!que.isEmpty()) { int v = que.remove(0); for (Q nv : V.get(v)) { if (nv.d >= w) { if (dist[nv.i] < 0) { dist[nv.i] = dist[v] + 1; if (nv.i == n - 1) { return dist[nv.i]; } que.add(nv.i); } } } } return dist[n-1]; } }