[BOJ] 2908 상수 (JAVA)

joyful·2021년 4월 10일
0

Algorithm

목록 보기
47/65

✅ 문제

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

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

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

✅ 입력

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

✅ 출력

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

✅ 예제 1

▼ 입력

734 893

▼ 출력

437

풀이

  1. 두 수를 문자열로 입력받은 뒤 StringTokenizer를 사용하여 공백을 기준으로 두 수를 분리하고, 거꾸로 읽은 수를 저장할 배열(result)을 생성한다.
  2. for문을 실행하여 각 숫자의 자리를 거꾸로 추출(String.charAt())하며 String 타입의 문자열(temp)에 더한다. 완성된 값은 result에 저장한다.
  3. 루프를 빠져나오면 result에 저장된 값들을 비교하여 큰 수를 출력한다.

💻 코드

import java.util.Scanner;
import java.util.StringTokenizer;

public class Main {
	public static void main(String[] args) {
		Scanner scanner = new Scanner(System.in);
		StringTokenizer st = new StringTokenizer(scanner.nextLine());	// 두 수를 입력 받아 분리
		scanner.close();
		
		int n = st.countTokens();	// 토큰의 갯수 구하기
		int[] result = new int[n];	// 거꾸로 읽은 수을 저장할 배열을 생성하고 토큰의 갯수만큼 길이를 설정
		
		for(int i=0; i<n; i++) {	// 입력받은 숫자들을
			String num = st.nextToken();	// 하나씩 분리
			String temp = "";
			int idx = num.length()-1;	// 일의 자리부터 저장하기 위함
			for(int j=idx; j>=0; j--)	// 거꾸로 읽어서 문자열에 저장
				temp += num.charAt(j);
			result[i] = Integer.parseInt(temp);	// 배열에 거꾸로 읽은 숫자 저장
		}
		
		//값 비교
		if(result[0] > result[1])
			System.out.println(result[0]);
		else
			System.out.println(result[1]);
	}
}
profile
기쁘게 코딩하고 싶은 백엔드 개발자

0개의 댓글