본문 바로가기

개발(합니다)/알고리즘&코테

알고리즘 단계별로 풀어보기 : BOJ-2908(상수)

반응형

문제(출처)

상근이의 동생 상수는 수학을 정말 못한다. 

상수는 숫자를 읽는데 문제가 있다. 

이렇게 수학을 못하는 상수를 위해서 상근이는 수의 크기를 비교하는 문제를 내주었다. 

상근이는 세 자리 수 두 개를 칠판에 써주었다. 

그 다음에 크기가 큰 수를 말해보라고 했다.


상수는 수를 다른 사람과 다르게 거꾸로 읽는다. 

예를 들어, 734과 893을 칠판에 적었다면, 상수는 이 수를 437과 398로 읽는다. 

따라서, 상수는 두 수중 큰 수인 437을 큰 수라고 말할 것이다.

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


입력

첫째 줄에 상근이가 칠판에 적은 두 수 A와 B가 주어진다. 

두 수는 같지 않은 세 자리 수이며, 0이 포함되어 있지 않다.


출력

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


예제 입력

734 893


예제 출력

437


내 풀이

import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;

public class Main {
    public static void main(String args[]) {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
        
        try {
            String[] strNum = br.readLine().split(" ");
            String[] num = new String[strNum.length];
//          거꾸로 저장 할 문자열 배열을 선언합니다.
            for(int i = 0; i < strNum.length; i++) {
//              입력 받은 문자열 만큼 반복합니다.
                num[i]="";
//              거꾸로 저장 할 문자열을 초기화합니다.
                for(int j = strNum.length; j >= 0 ; j--) {
//                  입력 받은 문자열을 거꾸로 하나의 문자씩 거내 저장합니다.
                    num[i]+=String.valueOf(strNum[i].charAt(j));
                }
            }
 
            int num1 = Integer.parseInt(num[0]);
            int num2 = Integer.parseInt(num[1]);
//          두 수를 정수화 하여 비교 후 큰 수를 출력합니다.
            if( num1 > num2) {
                bw.write(String.valueOf(num1));
            }else if(num1 < num2) {
                bw.write(String.valueOf(num2));
            }else {
                
            }
            bw.flush();
            bw.close();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}


내 풀이 해석

거꾸로 저장 할 문자열을 선언하고 초기화합니다.
입력 입은 문자열 만큼 반복합니다.
입력 받은 값의 마지막 인덱스부터 첫 번째 인덱스까지 반복하여 저장합니다.
두 수를 비교하여 출력합니다.


반응형