본문 바로가기
백준/1 - 5000

[백준] 2123번 : 인간 탑 쌓기

by lms0806 2024. 11. 17.
728x90

https://www.acmicpc.net/problem/2123

 

모든 몸무게의 합 - 본인 몸무게 - 본인 힘으로 위험도들을 모은 후, 정렬한 다음 탑 쌓아가면서 최대 위험도를 구하면 된다.

 

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.Arrays;
import java.util.StringTokenizer;

public class Main {
	public static void main(String[] args) throws IOException{
		BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
		
		int n = Integer.parseInt(br.readLine());
		
		int[][] arr = new int[n][2];
		
		int weightSum = 0;
		for(int i = 0; i < n; i++) {
			StringTokenizer st = new StringTokenizer(br.readLine());
			
			arr[i][0] = Integer.parseInt(st.nextToken());
			arr[i][1] = Integer.parseInt(st.nextToken());
			weightSum += arr[i][0];
		}
		
		Node[] dangers = new Node[n];
		
		for(int i = 0; i < n; i++) {
			dangers[i] = new Node(i, weightSum - arr[i][0] - arr[i][1]);
		}
		
		Arrays.sort(dangers);
		
		int answer = dangers[0].danger;
		int num = arr[dangers[0].idx][0];
		for(int i = 1; i < n; i++) {
			answer = Math.max(answer, dangers[i].danger - num);
			num += arr[dangers[i].idx][0];
		}
		System.out.print(answer);
	}
}

class Node implements Comparable<Node> {
	int idx, danger;
	
	public Node(int idx, int danger) {
		this.idx = idx;
		this.danger = danger;
	}
	
	@Override
	public int compareTo(Node o) {
		return this.danger - o.danger;
	}
}
728x90

'백준 > 1 - 5000' 카테고리의 다른 글

[백준] 2325번 : 개코전쟁  (0) 2024.12.08
[백준] 3135번 : 라디오  (0) 2024.11.13
[백준] 2785번 : 체인  (0) 2024.11.09
[백준] 1715번 : 카드 정렬하기(JAVA)  (0) 2021.10.29
[백준] 2075번 : N번째 큰 수(JAVA)  (0) 2021.10.25

댓글