[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 함수를 이용하여 쉽게 수를 뒤집을 수 있었다. 그런 다음 대소 비교를 통해 조건에 알맞은 결과를 출력하였는데 알고리즘, 코딩 테스트 등에서는 어느 함수까지 사용할 수 있는지를 모르겠다. 지금처럼 기존에 존재하는 함수를 사용하면 쉽게 구할 수 있는데 이렇게 사용하지 못한다면 아마도 리버스 함수를 직접 구현하는 단계부터 진행해야 할 것이다.


소스코드 보러가기

Categories:

Updated:

Leave a comment