240813 KCM Travel

Jongleee·2024년 8월 13일
0

TIL

목록 보기
650/786
static class Ticket {
	int to;
	int cost;
	int time;

	Ticket(int to, int cost, int time) {
		this.to = to;
		this.cost = cost;
		this.time = time;
	}
}

static class Airport implements Comparable<Airport> {
	int airportNum;
	int minTime;

	Airport(int airportNum, int minTime) {
		this.airportNum = airportNum;
		this.minTime = minTime;
	}

	@Override
	public int compareTo(Airport other) {
		return this.minTime - other.minTime;
	}
}

static int[][] dp;
static int numOfAirports;
static int maxCost;
static final int INF = 93000;
static List<Ticket>[] flights;

@SuppressWarnings("unchecked")
public static void main(String[] args) throws Exception {
	BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
	BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));

	int testCases = Integer.parseInt(br.readLine());

	for (int i = 0; i < testCases; i++) {
		StringTokenizer st = new StringTokenizer(br.readLine());
		numOfAirports = Integer.parseInt(st.nextToken());
		maxCost = Integer.parseInt(st.nextToken());
		int numOfTickets = Integer.parseInt(st.nextToken());

		dp = new int[numOfAirports + 1][maxCost + 1];
		for (int j = 2; j <= numOfAirports; j++) {
			Arrays.fill(dp[j], INF);
		}

		flights = new ArrayList[numOfAirports + 1];
		for (int j = 0; j <= numOfAirports; j++) {
			flights[j] = new ArrayList<>();
		}

		for (int j = 0; j < numOfTickets; j++) {
			st = new StringTokenizer(br.readLine());
			int from = Integer.parseInt(st.nextToken());
			int to = Integer.parseInt(st.nextToken());
			int cost = Integer.parseInt(st.nextToken());
			int time = Integer.parseInt(st.nextToken());
			flights[from].add(new Ticket(to, cost, time));
		}

		findMinTravelTime();

		int result = INF;
		for (int k = 0; k <= maxCost; k++) {
			result = Math.min(result, dp[numOfAirports][k]);
		}

		if (result == INF) {
			bw.write("Poor KCM\n");
		} else {
			bw.write(result + "\n");
		}

	}

	bw.flush();
	bw.close();
}

static void findMinTravelTime() {
	PriorityQueue<Airport> queue = new PriorityQueue<>();
	boolean[] visited = new boolean[numOfAirports + 1];

	queue.add(new Airport(1, 0));
	dp[1][0] = 0;

	while (!queue.isEmpty()) {
		Airport currentAirport = queue.poll();

		if (currentAirport.airportNum == numOfAirports)
			return;
		if (visited[currentAirport.airportNum])
			continue;
		visited[currentAirport.airportNum] = true;

		for (Ticket ticket : flights[currentAirport.airportNum]) {
			if (ticket.cost > maxCost)
				continue;

			int newCost = INF;
			for (int k = 0; k <= maxCost - ticket.cost; k++) {
				if (dp[currentAirport.airportNum][k] != INF) {
					if (dp[ticket.to][k + ticket.cost] > dp[currentAirport.airportNum][k] + ticket.time) {
						dp[ticket.to][k + ticket.cost] = dp[currentAirport.airportNum][k] + ticket.time;
						newCost = newCost > dp[currentAirport.airportNum][k] + ticket.time
								? dp[currentAirport.airportNum][k] + ticket.time
								: newCost;
					}
				}
			}
			if (newCost != INF)
				queue.add(new Airport(ticket.to, newCost));
		}
	}
}

출처:https://www.acmicpc.net/problem/10217

0개의 댓글