[BOJ] #2908 - 상수
👻 상수
🌱 문제
상근이의 동생 상수는 수학을 정말 못한다. 상수는 숫자를 읽는데 문제가 있다. 이렇게 수학을 못하는 상수를 위해서 상근이는 수의 크기를 비교하는 문제를 내주었다. 상근이는 세 자리 수 두 개를 칠판에 써주었다. 그 다음에 크기가 큰 수를 말해보라고 했다.
상수는 수를 다른 사람과 다르게 거꾸로 읽는다. 예를 들어, 734와 893을 칠판에 적었다면, 상수는 이 수를 437과 398로 읽는다. 따라서, 상수는 두 수중 큰 수인 437을 큰 수라고 말할 것이다.
두 수가 주어졌을 때, 상수의 대답을 출력하는 프로그램을 작성하시오.
- 시간 제한 : 1초
- 메모리 제한 : 128 MB
🌱 입력
첫째 줄에 상근이가 칠판에 적은 두 수 A와 B가 주어진다. 두 수는 같지 않은 세 자리 수이며, 0이 포함되어 있지 않다.
🌱 출력
철째 줄에 상수의 대답을 출력한다.
🌱 예제
🪐 입출력 1
- 입력
734 893
- 출력
437
🪐 입출력 2
- 입력
221 231
- 출력
132
🪐 입출력 3
- 입력
839 237
- 출력
938
👻 풀이
#include <iostream>
#include <string>
#include <algorithm>
using namespace std;
int main()
{
ios::sync_with_stdio(false); cin.tie(NULL); cout.tie(NULL);
// 상수
string a, b;
cin >> a >> b;
reverse(a.begin(), a.end());
reverse(b.begin(), b.end());
if (stoi(a) > stoi(b)) cout << a;
else cout << b;
return 0;
}
- 시간 : 0 ms
- 메모리 : 2024 KB
👻 글을 마치며
두 수를 숫자가 아닌 문자열로 받아 reverse 함수를 이용하여 쉽게 수를 뒤집을 수 있었다. 그런 다음 대소 비교를 통해 조건에 알맞은 결과를 출력하였는데 알고리즘, 코딩 테스트 등에서는 어느 함수까지 사용할 수 있는지를 모르겠다. 지금처럼 기존에 존재하는 함수를 사용하면 쉽게 구할 수 있는데 이렇게 사용하지 못한다면 아마도 리버스 함수를 직접 구현하는 단계부터 진행해야 할 것이다.
Leave a comment