[BaekJoon] 2752번 - 세수 정렬 (java)
1. 문제
👉 문제 바로가기
- 조건
시간 제한 | 메모리 제한 |
---|---|
1초 | 128MB |
- 문제
동규는 세수를 하다가 정렬이 하고싶어졌다.
숫자 세 개를 생각한 뒤에, 이를 오름차순으로 정렬하고 싶어 졌다.
숫자 세 개가 주어졌을 때, 가장 작은 수, 그 다음 수, 가장 큰 수를 출력하는 프로그램을 작성하시오.
- 입력
숫자 세 개가 주어진다. 이 숫자는 1보다 크거나 같고, 1,000,000보다 작거나 같다. 이 숫자는 모두 다르다.
- 출력
제일 작은 수, 그 다음 수, 제일 큰 수를 차례대로 출력한다.
- 예제
입력 | 출력 |
---|---|
3 1 2 | 1 2 3 |
2. 풀이
이 문제는 자바에서 기본으로 제공되는 Arrays.sort() 함수
또는 퀵 정렬
, 선택 정렬
, 삽입 정렬
을 이용해서 풀 수 있다.
여기선 Arrays.sort() 함수를 사용할 것이다.
2개의 입력방식을 사용해서 결과를 출력한다.
- Scanner 클래스
- BufferedReader 클래스
2-1. Scanner 클래스
import java.util.Scanner;
import java.util.Arrays;
public class Main{
public static void main(String[] args){
Scanner sc = new Scanner(System.in);
int[] arr = new int[3];
for(int i=0;i<3;i++){
arr[i] = sc.nextInt();
}
Arrays.sort(arr); // 배열 정렬
for(int i=0;i<3;i++){
System.out.print(arr[i] + " ");
}
}
}
위와같이 객체를 생성할 때, Scanner(System.in) 에서
System.in
은 입력한 값을Byte 단위
로 읽는 것을 뜻한다.
int형 데이터를 입력받기 위해
nextInt()
메서드를 사용하고 int 배열에 저장한다.
Arrays.sort(arr)
을 사용해 배열을 오름차순으로 정렬한다.
[여기서 잠깐!]
2-2. BufferedReader 클래스 사용
BufferedReader는 readLine()
메서드를 사용해 한 행을 전부 읽는다.
이를 공백단위로 분리해야 하는데, StringTokenizer 클래스를 사용하여 문제를 풀어보자.
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.io.IOException;
import java.util.StringTokenizer;
import java.util.Arrays;
public class Main{
public static void main(String[] args)throws IOException{
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
StringTokenizer st = new StringTokenizer(br.readLine());
int[] arr = new int[3];
for(int i=0;i<3;i++){
arr[i] = Integer.parseInt(st.nextToken());
}
Arrays.sort(arr);
for(int num : arr) System.out.print(num + " ");
}
}
readLine()
은 한 줄을 통째로 읽어 String으로 반환하기 때문에, StringTokenizer 클래스의nextToken()
를 이용해 공백으로 구분된 입력값들을 순서대로 가져온다.
Integer.parseInt()
을 사용해 String형을int형으로 변환
시켜준다.
Arrays.sort(arr)
을 사용해 배열을 오름차순으로 정렬한다.
[여기서 잠깐!]
BufferedReader 클래스
에 대해 더 알아보고 싶으면 여기를 클릭하면 된다.3. Scanner VS BufferedReader 성능 비교
입력의 경우 확실히 Scanner 보다는 BufferedReader 가 빠른 것을 볼 수 있다.
관련 페이지
Leave a comment