자바알고리즘 - 문자열 - 백준 2908 상수

 

 

문제

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

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

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

 

생각

1. 세 자리 수 두개만 주어진다고 했기 때문에 주어진 숫자를 나머지를 이용해 나누어 뒤집어서 계산한다.

2. 뒤집힌 숫자 = 뒤집힌숫자*10 + 기존숫자%10
    기존숫자 /= 10

 

코드

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.StringTokenizer;

public class Main {
    public static void main(String[] args) throws IOException {
        BufferedReader bf =new BufferedReader(new InputStreamReader(System.in));
        StringTokenizer st = new StringTokenizer(bf.readLine());
        int N = Integer.parseInt(st.nextToken());
        int M = Integer.parseInt(st.nextToken());
        int ReverseN = 0;
        int ReverseM =0;
        while(N!=0) {
            ReverseN = (ReverseN *10) + (N%10);
            N /= 10;
        }
        while(M!=0) {
            ReverseM = (ReverseM *10) + (M%10);
            M /= 10;
        }
        if(ReverseN>ReverseM) {
            System.out.println(ReverseN);
        }
        else {
            System.out.println(ReverseM);
        }
    }
}

 

 

 

+ Recent posts