Submission #1284668


Source Code Expand

import java.io.BufferedReader;
import java.io.Closeable;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.PrintWriter;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
import java.util.HashMap;
import java.util.HashSet;
import java.util.LinkedList;
import java.util.Map.Entry;
import java.util.PriorityQueue;
import java.util.Scanner;
import java.util.StringTokenizer;
import java.util.TreeMap;

public class Main {
	
	public static void bfs(int start, ArrayList<HashMap<Integer, Long>> adj, boolean[] visited){
		LinkedList<Integer> queue = new LinkedList<Integer>();
		
		queue.add(start);
		visited[start] = true;
		while(!queue.isEmpty()){
			final int node = queue.poll();
			
			for(final Entry<Integer, Long> entry : adj.get(node).entrySet()){
				final int next = entry.getKey();
				
				if(visited[next]){ continue; }
				
				visited[next] = true;
				queue.add(next);
			}
		}
	}
	
	public static void main(String[] args) throws IOException {
		try(Scanner sc = new Scanner(System.in)){
			final int N = sc.nextInt();
			final int M = sc.nextInt();
			
			ArrayList<HashMap<Integer, Long>> adj = new ArrayList<HashMap<Integer, Long>>();
			ArrayList<HashMap<Integer, Long>> rev_adj = new ArrayList<HashMap<Integer, Long>>();
			for(int i = 0; i < N; i++){ adj.add(new HashMap<Integer, Long>()); }
			for(int i = 0; i < N; i++){ rev_adj.add(new HashMap<Integer, Long>()); }
			
			for(int i = 0; i < M; i++){
				final int a = sc.nextInt() - 1;
				final int b = sc.nextInt() - 1;
				final long c = sc.nextLong();
				
				adj.get(a).put(b, c);
				rev_adj.get(b).put(a, -c);
			}
			
			boolean[] can_entry = new boolean[N];
			bfs(N - 1, rev_adj, can_entry);
			//System.out.println(Arrays.toString(can_entry));
			
			long[] costs = new long[N];
			Arrays.fill(costs, Long.MIN_VALUE);
			costs[0] = 0;
			
			LinkedList<Integer> queue = new LinkedList<Integer>();
			boolean[] in_queue = new boolean[N];
			int[] in_count = new int[N];
			
			queue.add(0);
			in_queue[0] = true;
			in_count[0] = 1;
			
			while(!queue.isEmpty()){
				final int node = queue.poll();
				in_queue[node] = false;
				
				if(in_count[node] > N){
					System.out.println("inf");
					return;
				}
				
				for(final Entry<Integer, Long> entry : adj.get(node).entrySet()){
					final int next = entry.getKey();
					final long next_cost = costs[node] + entry.getValue();
					
					if(!can_entry[next]){ continue; }
					if(costs[next] >= next_cost){ continue; }
					
					costs[next] = next_cost;
					if(!in_queue[next]){
						queue.add(next);	
						in_queue[next] = true;
						in_count[next] += 1;
					}
				}
			}
			
			System.out.println(costs[N - 1]);
		}
	}
	
	public static class Scanner implements Closeable {
		private BufferedReader br;
		private StringTokenizer tok;
 
		public Scanner(InputStream is) throws IOException {
			br = new BufferedReader(new InputStreamReader(is));
		}
 
		private void getLine() throws IOException {
			while (!hasNext()) {
				tok = new StringTokenizer(br.readLine());
			}
		}
 
		private boolean hasNext() {
			return tok != null && tok.hasMoreTokens();
		}
 
		public String next() throws IOException {
			getLine();
			return tok.nextToken();
		}
 
		public int nextInt() throws IOException {
			return Integer.parseInt(next());
		}
 
		public long nextLong() throws IOException {
			return Long.parseLong(next());
		}
 
		public double nextDouble() throws IOException {
			return Double.parseDouble(next());
		}
		
		public int[] nextIntArray(int n) throws IOException {
			final int[] ret = new int[n];
			for(int i = 0; i < n; i++){
				ret[i] = this.nextInt();
			}
			return ret;
		}
		
		public long[] nextLongArray(int n) throws IOException {
			final long[] ret = new long[n];
			for(int i = 0; i < n; i++){
				ret[i] = this.nextLong();
			}
			return ret;
		}
 
		public void close() throws IOException {
			br.close();
		}
	}
}

Submission Info

Submission Time
Task D - Score Attack
User mondatto
Language Java8 (OpenJDK 1.8.0)
Score 400
Code Size 4135 Byte
Status AC
Exec Time 309 ms
Memory 45464 KB

Judge Result

Set Name Sample All
Score / Max Score 0 / 0 400 / 400
Status
AC × 3
AC × 30
Set Name Test Cases
Sample sample_01.txt, sample_02.txt, sample_03.txt
All sample_01.txt, sample_02.txt, sample_03.txt, subtask_1_1.txt, subtask_1_10.txt, subtask_1_11.txt, subtask_1_12.txt, subtask_1_13.txt, subtask_1_14.txt, subtask_1_15.txt, subtask_1_16.txt, subtask_1_17.txt, subtask_1_18.txt, subtask_1_19.txt, subtask_1_2.txt, subtask_1_20.txt, subtask_1_21.txt, subtask_1_22.txt, subtask_1_23.txt, subtask_1_24.txt, subtask_1_25.txt, subtask_1_26.txt, subtask_1_27.txt, subtask_1_3.txt, subtask_1_4.txt, subtask_1_5.txt, subtask_1_6.txt, subtask_1_7.txt, subtask_1_8.txt, subtask_1_9.txt
Case Name Status Exec Time Memory
sample_01.txt AC 70 ms 21332 KB
sample_02.txt AC 71 ms 20692 KB
sample_03.txt AC 73 ms 21332 KB
subtask_1_1.txt AC 89 ms 21076 KB
subtask_1_10.txt AC 79 ms 21332 KB
subtask_1_11.txt AC 143 ms 27988 KB
subtask_1_12.txt AC 292 ms 44512 KB
subtask_1_13.txt AC 74 ms 19412 KB
subtask_1_14.txt AC 279 ms 45260 KB
subtask_1_15.txt AC 309 ms 45464 KB
subtask_1_16.txt AC 72 ms 17876 KB
subtask_1_17.txt AC 78 ms 18772 KB
subtask_1_18.txt AC 104 ms 23764 KB
subtask_1_19.txt AC 122 ms 20692 KB
subtask_1_2.txt AC 99 ms 21844 KB
subtask_1_20.txt AC 76 ms 18388 KB
subtask_1_21.txt AC 106 ms 18132 KB
subtask_1_22.txt AC 120 ms 21332 KB
subtask_1_23.txt AC 72 ms 20180 KB
subtask_1_24.txt AC 109 ms 19028 KB
subtask_1_25.txt AC 100 ms 19028 KB
subtask_1_26.txt AC 95 ms 18260 KB
subtask_1_27.txt AC 95 ms 21204 KB
subtask_1_3.txt AC 105 ms 22996 KB
subtask_1_4.txt AC 107 ms 19284 KB
subtask_1_5.txt AC 229 ms 35876 KB
subtask_1_6.txt AC 289 ms 43432 KB
subtask_1_7.txt AC 100 ms 18260 KB
subtask_1_8.txt AC 100 ms 19924 KB
subtask_1_9.txt AC 70 ms 18260 KB