[백준 알고리즘 문제풀이][JAVA][2908번] 상수

문제 - 백준 문제 바로가기

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

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

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



입력

첫째 줄에 두 정수 H와 M이 주어진다. (0 ≤ H ≤ 23, 0 ≤ M ≤ 59)
그리고 이것은 현재 상근이가 설정한 놓은 알람 시간 H시 M분을 의미한다.

입력 시간은 24시간 표현을 사용한다.
24시간 표현에서 하루의 시작은 0:0(자정)이고, 끝은 23:59(다음날 자정 1분 전)이다.
시간을 나타낼 때, 불필요한 0은 사용하지 않는다.



출력

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



시간제한

1초



알고리즘 유형

  • 수학
  • 구현


예제입력 1

734 893

예제출력 1

437


예제입력 2

221 231

예제출력 2

132


예제입력 3

839 237

예제출력 3

938




풀이 1


import java.io.*;
import java.util.Scanner;

public class No2908_상수 {
  public static void main(String[] args)  throws IOException {

    go();

  }


  public static void go() throws IOException {
    BufferedReader br = new BufferedReader( new InputStreamReader( System.in ) );
    BufferedWriter bw = new BufferedWriter( new OutputStreamWriter( System.out ) );
    String[] str = br.readLine().split(" ");
    int[] numArr = {0, 0};
    for(int x=0; x<str.length; x++){
      for(int y = 0; y < str[x].length(); y++){
        numArr[x] += Math.pow(10.0, y)*Integer.parseInt(str[x].substring(y, y+1));
      }
    }
    bw.write((numArr[0]>numArr[1]?numArr[0]:numArr[1])+"");
    bw.flush();
    //bw.close();
  }

}



풀이 2


import java.io.*;
import java.util.Scanner;

public class No2908_상수 {
  public static void main(String[] args)  throws IOException {

    go2();

  }

  public static void go2() throws IOException {
    Scanner sc = new Scanner(System.in);

    String[] a = sc.next().split("");
    int aa = Integer.parseInt(a[2]+a[1]+a[0]);
    String[] b = sc.next().split("");
    int bb = Integer.parseInt(b[2]+b[1]+b[0]);
    if(aa>bb) System.out.println(aa);
    else System.out.println(bb);
  }

}






GitHub 소스는 아래에서 확인 가능합니다.

[풀이1]




마지막 수정