제출 #495350

#제출 시각아이디문제언어결과실행 시간메모리
495350vijayRobot (JOI21_ho_t4)Java
0 / 100
1419 ms76712 KiB
import java.io.*; import java.util.*; public class Main { public static void main(String[] args) throws IOException, FileNotFoundException { // Scanner in = new Scanner(new File("test.in")); Kattio in = new Kattio(); int N = in.nextInt(); int M = in.nextInt(); ArrayList<Road>[] adj = new ArrayList[N]; for(int i = 0; i < N; i++){ adj[i] = new ArrayList<>(); } for(int i = 0; i < M; i++){ int a = in.nextInt() - 1; int b = in.nextInt() - 1; int color = in.nextInt(); int cost = in.nextInt(); adj[a].add(new Road(a, b, color, cost)); adj[b].add(new Road(b, a, color, cost)); } PriorityQueue<State> pq = new PriorityQueue<>(); pq.add(new State(0, 0)); boolean[] visited = new boolean[N]; long ans = -1; while(!pq.isEmpty()){ State curr = pq.poll(); if(visited[curr.pos]){ continue; } visited[curr.pos] = true; if(curr.pos == N - 1){ ans = curr.dist; } // go to each one and see the count HashMap<Integer, Integer> count = new HashMap<>(); for(Road r: adj[curr.pos]){ if(!count.containsKey(r.color)){ count.put(r.color, 1); } else { count.put(r.color, count.get(r.color) + 1); } } for(Road r: adj[curr.pos]){ if(count.get(r.color) == 1){ pq.add(new State(r.to, curr.dist)); } else { pq.add(new State(r.to, curr.dist + r.cost)); } } } System.out.println(ans); } static class Kattio extends PrintWriter { private BufferedReader r; private StringTokenizer st; // standard input public Kattio() { this(System.in, System.out); } public Kattio(InputStream i, OutputStream o) { super(o); r = new BufferedReader(new InputStreamReader(i)); } // USACO-style file input public Kattio(String problemName) throws IOException { super(new FileWriter(problemName + ".out")); r = new BufferedReader(new FileReader(problemName + ".in")); } // returns null if no more input public String next() { try { while (st == null || !st.hasMoreTokens()) st = new StringTokenizer(r.readLine()); return st.nextToken(); } catch (Exception e) { } return null; } public int nextInt() { return Integer.parseInt(next()); } public double nextDouble() { return Double.parseDouble(next()); } public long nextLong() { return Long.parseLong(next()); } } public static class State implements Comparable<State>{ int pos; long dist; public State(int pos, long dist){ this.pos = pos; this.dist = dist; } public int compareTo(State s){ return Long.compare(dist, s.dist); } } public static class Road { int a, to, color, cost; public Road(int a, int to, int color, int cost){ this.a = a; this.to = to; this.color = color; this.cost = cost; } } }

컴파일 시 표준 에러 (stderr) 메시지

Note: Main.java uses unchecked or unsafe operations.
Note: Recompile with -Xlint:unchecked for details.
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...