728x90
2908번: 상수
상근이의 동생 상수는 수학을 정말 못한다. 상수는 숫자를 읽는데 문제가 있다. 이렇게 수학을 못하는 상수를 위해서 상근이는 수의 크기를 비교하는 문제를 내주었다. 상근이는 세 자리 수 두
www.acmicpc.net
문제
상근이의 동생 상수는 수학을 정말 못한다. 상수는 숫자를 읽는데 문제가 있다. 이렇게 수학을 못하는 상수를 위해서 상근이는 수의 크기를 비교하는 문제를 내주었다. 상근이는 세 자리 수 두 개를 칠판에 써주었다. 그 다음에 크기가 큰 수를 말해보라고 했다.
상수는 수를 다른 사람과 다르게 거꾸로 읽는다. 예를 들어, 734와 893을 칠판에 적었다면, 상수는 이 수를 437과 398로 읽는다. 따라서, 상수는 두 수중 큰 수인 437을 큰 수라고 말할 것이다.
두 수가 주어졌을 때, 상수의 대답을 출력하는 프로그램을 작성하시오.
입력
첫째 줄에 상근이가 칠판에 적은 두 수 A와 B가 주어진다. 두 수는 같지 않은 세 자리 수이며, 0이 포함되어 있지 않다.
출력
첫째 줄에 상수의 대답을 출력한다.
풀이
두 가지 방법으로 풀어 보았다
1. 곱셈과 나머지를 이용해 뒤집는 방법
2. String과 charAt을 이용해 뒤집는 방법
두 가지 방법 모두 풀어 보았고, 결과는 n1과 n2를 같은 방법(둘 다 1이거나 둘 다 2)으로 제출했다
코드
import java.io.*;
import java.util.*;
public class B2_2908_상수 {
public static void main(String[] args) throws Exception {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
StringTokenizer st = new StringTokenizer(br.readLine());
// 1번 방법
int n1 = Integer.parseInt(st.nextToken());
int tmp = n1/100; // 100의자리 -> 1의자리
n1 = ((n1%100)%10)*100 + // 1의 자리 -> 100의 자리
((n1%100)/10)*10 + // 10의 자리 -> 10의 자리
tmp; // 1의 자리 -> 1의 자리
// 2번 방법
String str = st.nextToken();
int n2 = 0;
for (int i = 0; i < 3; i++) {
// 100의자리수는 0번째 자리기 때문에 0번째 자리 수*10의 0승
// 10의자리수는 1번째 자리기 때문에 1번째 자리 수*10의 1승
// 1의자리수는 2번째 자리기 때문에 2번째 자리 수*10의 2승
n2 += (int)Math.pow(10, i) * (str.charAt(i) - '0');
System.out.println(n2);
}
if(n1 > n2) System.out.println(n1);
else System.out.println(n2);
}
}
결과
#자바 #java #boj #백준 #알고리즘
728x90
'알고리즘 > BOJ' 카테고리의 다른 글
[JAVA][BOJ][S4] 26069. 붙임성 좋은 총총이 (0) | 2022.11.30 |
---|---|
[JAVA][BOJ][S1] 6118. 숨바꼭질 (0) | 2022.11.30 |
[JAVA][BOJ][S1] 1080. 행렬 (0) | 2022.07.28 |
[JAVA][BOJ][S1] 11057. 오르막 수 (0) | 2022.07.27 |
[JAVA][BOJ][S3] 1449. 수리공 항승 (0) | 2022.07.25 |