• 문제 링크
2012번: 등수 매기기
첫째 줄에 자연수 N이 주어진다. (1 ≤ N ≤ 500,000) 둘째 줄부터 N개의 줄에 걸쳐 각 사람의 예상 등수가 순서대로 주어진다. 예상 등수는 500,000 이하의 자연수이다.
www.acmicpc.net
• 풀이 과정
불만도의 합을 구하기 위해 학생이 예상한 등수와 실제 등수의 차를 구하되,
그 값이 최소가 되기 위해 오름차순으로 예상 등수를 정렬한 후에 값을 구한다.
이때 모든 학생이 자신의 등수를 1로 예상할 경우,
불만도의 합이 int 범위를 벗어날 수 있기 때문에 long 형으로 sum 변수를 선언한다.
이후 각각의 차를 구해 sum 변수에 누적한 값을 정답으로써 출력한다.
• 풀이 코드
import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.util.Arrays;
public class Main {
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
int n = Integer.parseInt(br.readLine());
int[] arr = new int[n];
for (int i = 0; i < n; i++)
arr[i] = Integer.parseInt(br.readLine());
Arrays.sort(arr);
long sum = 0;
for (int i = 0; i < n; i++)
sum += Math.abs(arr[i] - (i + 1));
bw.write(String.valueOf(sum));
bw.flush();
}
}
'Problem Solving > Baekjoon' 카테고리의 다른 글
[백준] 2141 우체국 - Greedy / Java (0) | 2022.12.22 |
---|---|
[백준] 2212 센서 - Greedy / Java (0) | 2022.12.21 |
[백준] 2841 외계인의 기타 연주 - Data Structure / Java (0) | 2022.12.19 |
[백준] 2304 창고 다각형 - Data Structure / Java (0) | 2022.12.18 |
[백준] 14713 앵무새 - Data Structure / Java (0) | 2022.12.17 |
댓글