티스토리 뷰

알고리즘

백준 2908 상수 (Java)

파이 2024. 3. 29. 07:27

 

문제

상근이의 동생 상수는 수학을 정말 못한다. 상수는 숫자를 읽는데 문제가 있다. 이렇게 수학을 못하는 상수를 위해서 상근이는 수의 크기를 비교하는 문제를 내주었다. 상근이는 세 자리 수 두 개를 칠판에 써주었다. 그 다음에 크기가 큰 수를 말해보라고 했다.

상수는 수를 다른 사람과 다르게 거꾸로 읽는다. 예를 들어, 734와 893을 칠판에 적었다면, 상수는 이 수를 437과 398로 읽는다. 따라서, 상수는 두 수중 큰 수인 437을 큰 수라고 말할 것이다.

두 수가 주어졌을 때, 상수의 대답을 출력하는 프로그램을 작성하시오.

입력

첫째 줄에 상근이가 칠판에 적은 두 수 A와 B가 주어진다. 두 수는 같지 않은 세 자리 수이며, 0이 포함되어 있지 않다.

출력

첫째 줄에 상수의 대답을 출력한다.

예제 입력 1 

734 893

예제 출력 1 

437

예제 입력 2 

221 231

예제 출력 2 

132

예제 입력 3 

839 237

 

예제 출력 3 

938

 

 

풀이

import java.util.*;
import java.lang.*;
import java.io.*;

class Main {
	public static void main (String[] args) throws java.lang.Exception {

    Scanner sc = new Scanner(System.in);
    
    int n1 = sc.nextInt();
    int n2 = sc.nextInt();
    
    sc.close();
    
    n1 = Integer.parseInt(new StringBuilder().append(n1).reverse().toString());
    n2 = Integer.parseInt(new StringBuilder().append(n2).reverse().toString());
    
    System.out.print(n1>n2 ? n1 : n2);
    
	}
}

 

StringBuilder에서 제공하는 메소드인 reverse를 사용하기 위해서 바꿔준다.

그리고 정수형으로 바꾸기 위해서 toString으로 변환 후 Integer.parseInt를 사용한다.

 

간단한 문제인데 포스팅 하는 이유가.

머리속에 reverse가 생각이 안나서 

 

직접 n1의 100의 자리와 1의 자리를 바꿔주는 코드를 작성해서 

문제를 풀었었다. 

답은 맞추긴 했는데 절대 이렇게 접근하라고 문제를 낸 건 아닐것이라 확신했다.

 

StringBuilder, reverse에 익숙해지자 .. 후

공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2025/05   »
1 2 3
4 5 6 7 8 9 10
11 12 13 14 15 16 17
18 19 20 21 22 23 24
25 26 27 28 29 30 31
글 보관함