본문 바로가기
Algorithm

[백준 알고리즘 JAVA] 2908번 상수

by wook99 2024. 4. 7.

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

 

2908번: 상수

상근이의 동생 상수는 수학을 정말 못한다. 상수는 숫자를 읽는데 문제가 있다. 이렇게 수학을 못하는 상수를 위해서 상근이는 수의 크기를 비교하는 문제를 내주었다. 상근이는 세 자리 수 두

www.acmicpc.net

 

문제

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

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

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

입력

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

출력

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

 

 

핵심

1. scanner를 통해 문자열로 이루어진 세자리 수 A와 B를 입력받음.

2. 뒤집은 수를 담을 문자열 reverseA와 reverseB를 선언 및 초기화

3. 반복문을 통해 A와 B의 각 문자를 뒤에서부터 추출해서 reverseA와 reverseB에 대입

4. 삼항연산자를 통해 큰값을 출력 비교는 Integer.parseInt()를 통해서 수끼리 비교하고, 출력은 문자열로 했음.

import java.util.Arrays;
import java.util.Scanner;


public class Main {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        String A = scanner.next();
        String B = scanner.next();

        String reverseA = "";
        String reverseB = "";

        for (int i = A.length()-1; i >= 0; i--) {
            reverseA += String.valueOf(A.charAt(i));
            reverseB += String.valueOf(B.charAt(i));
        }

        System.out.println(Integer.parseInt(reverseA) > Integer.parseInt(reverseB) ? reverseA : reverseB);
    }
}