상수
https://www.acmicpc.net/problem/2908
시간 제한 | 메모리 제한 | 제출 | 정답 | 맞힌 사람 | 정답 비율 |
---|---|---|---|---|---|
1 초 | 128 MB | 104914 | 72637 | 62386 | 69.918% |
문제
상근이의 동생 상수는 수학을 정말 못한다.
상수는 숫자를 읽는데 문제가 있다.
이렇게 수학을 못하는 상수를 위해서 상근이는 수의 크기를 비교하는 문제를 내주었다.
상근이는 세 자리 수 두 개를 칠판에 써주었다.
그 다음에 크기가 큰 수를 말해보라고 했다.
상수는 수를 다른 사람과 다르게 거꾸로 읽는다.
예를 들어, 734와 893을 칠판에 적었다면, 상수는 이 수를 437과 398로 읽는다.
따라서, 상수는 두 수중 큰 수인 437을 큰 수라고 말할 것이다.
두 수가 주어졌을 때, 상수의 대답을 출력하는 프로그램을 작성하시오.
입력
첫째 줄에 상근이가 칠판에 적은 두 수 A와 B가 주어진다.
두 수는 같지 않은 세 자리 수이며, 0이 포함되어 있지 않다.
출력
첫째 줄에 상수의 대답을 출력한다.
예제 입력 1
734 893
예제 출력 1
437
예제 입력 2
221 231
예제 출력 2
132
예제 입력 3
839 237
예제 출력 3
938
출처
Contest > Croatian Open Competition in Informatics > COCI 2009/2010 > Contest #3 1번
- 문제를 번역한 사람: baekjoon
- 문제의 오타를 찾은 사람: eric00513, identity1978, jongfighter, pkcchoi3
- 데이터를 추가한 사람: ssuu0216
알고리즘 분류
문제의 흐름과 같이 A, B를 입력받고 뒤집는다. (문자열로 만들어서)
뒤집은 후에 다시 int 값으로 변경하고 크기를 비교하여 답을 출력한다.
reverse(), to_string(), stoi() 함수를 알고 있다면 쉽게 해결 할 수 있다.
통과된 코드
#include <iostream> #include <string> #include <algorithm> using namespace std; int A, B; string strA, strB; int main() { cin >> A >> B; strA = to_string(A); // int => string strB = to_string(B); // int => string reverse(strA.begin(), strA.end()); // 문자열 뒤집기 reverse(strB.begin(), strB.end()); // 문자열 뒤집기 A = stoi(strA); // string => int B = stoi(strB); // string => int cout << max(A, B); // 두 값 중에서 최댓값 출력 return 0; }
알고리즘 해더 파일을 추가하지 않아서 컴파일 에러가 발생 하였다.