Algorithm/Baekjoon

[백준 알고리즘][자바] 2751번 : 수 정렬하기 2

hyunipad 2022. 5. 3. 23:32
반응형

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

 

2751번: 수 정렬하기 2

첫째 줄에 수의 개수 N(1 ≤ N ≤ 1,000,000)이 주어진다. 둘째 줄부터 N개의 줄에는 수가 주어진다. 이 수는 절댓값이 1,000,000보다 작거나 같은 정수이다. 수는 중복되지 않는다.

www.acmicpc.net

 

이번 문제는 자바에 내장되어 있는 정렬 함수를 사용하여 푸는 문제이다.

자바에 내장되어 있는 정렬 함수는 Arrays.sort() 와 Collections.sort()가 있다.(자바 8기준)

 

2022.04.30 - [Programming/Java] - [Java] 자바 내장 정렬 함수 - Arrays.sort()

 

[Java] 자바 내장 정렬 함수 - Arrays.sort()

데이터들을 정렬시킬 때, 어떤 정렬 알고리즘을 사용해야 하는지 판단하는 중요한 요소중 하나는 시간 복잡도입니다. 자바 내부에서 사용하는 정렬은 시간 복잡도가 얼마인지 알 필요성이 있다

hyunipad.tistory.com

 

Arrays.sort()를 사용하여 문제를 풀면 시간초과가 난다.

앞서 작성한 글에서 Arrays.sort()의 시간 복잡도는 O(nlogn)이지만 최악의 경우 O(n^2)가 될 수 있다.

이 문제는 데이터 속에 O(n^2)가 걸리는 데이터가 있어 최악의 경우 O(nlogn)을 보장해야한다.

 

따라서 두번째 내장 정렬 함수인 Collections.sort()를 사용해야한다.

 

Collections.sort()는 TimSort이다.(TimSort에 대해서는 추후에 자세히 다루어 보도록 하겠습니다.)

TimSort는 InsertionSort와 MergerSort를 섞은 정렬 알고리즘이다.

TimSort의 시간 복잡도는 O(nlogn)~O(n)을 보장하기 때문에 이번 문제에서 사용한다.

 

풀이

import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.util.ArrayList;
import java.util.Collections;

public class Main {

	public static void main(String[] args) throws NumberFormatException, IOException {

		BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
		BufferedReader br = new BufferedReader(new InputStreamReader(System.in));

		int N = Integer.parseInt(br.readLine());
		
		ArrayList<Integer> list = new ArrayList<Integer>();
		
		for(int i = 0 ; i < N ; i++) {
			list.add(Integer.parseInt(br.readLine()));
		}
		
		Collections.sort(list);
		
		for(int i : list) {
			bw.write(String.valueOf(i) + "\n");
		}

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

}

 

반응형