https://www.acmicpc.net/problem/2908
2908번: 상수
상근이의 동생 상수는 수학을 정말 못한다. 상수는 숫자를 읽는데 문제가 있다. 이렇게 수학을 못하는 상수를 위해서 상근이는 수의 크기를 비교하는 문제를 내주었다. 상근이는 세 자리 수 두
www.acmicpc.net
c++로 백준 2908번 문제를 풀어보겠다.
문제
상근이의 동생 상수는 수학을 정말 못한다. 상수는 숫자를 읽는데 문제가 있다. 이렇게 수학을 못하는 상수를 위해서 상근이는 수의 크기를 비교하는 문제를 내주었다. 상근이는 세 자리 수 두 개를 칠판에 써주었다. 그 다음에 크기가 큰 수를 말해보라고 했다.
상수는 수를 다른 사람과 다르게 거꾸로 읽는다. 예를 들어, 734와 893을 칠판에 적었다면, 상수는 이 수를 437과 398로 읽는다. 따라서, 상수는 두 수중 큰 수인 437을 큰 수라고 말할 것이다.
두 수가 주어졌을 때, 상수의 대답을 출력하는 프로그램을 작성하시오.
입력
첫째 줄에 상근이가 칠판에 적은 두 수 A와 B가 주어진다. 두 수는 같지 않은 세 자리 수이며, 0이 포함되어 있지 않다.
출력
첫째 줄에 상수의 대답을 출력한다.
예제 입력 1 복사
734 893
예제 출력 1 복사
437
<문제 풀이>
1. string형태로 숫자두개를 입력받는다.
2. 각 숫자를 순서를 거꾸로 한 정수 형태로 다시 저장한다.
(첫번째 값을 불러와 10의 0제곱을 곱해 더해주고, 두번째값에 10의 1제곱을 곱한 것을 더해주고... 를 반복하면 새로운 형태, 즉 순서를 거꾸로 한 정수 형태로 만들어 줄 수 있다.)
3. 바뀐 값 두 개를 비교해 더 큰 값을 출력한다.
이 문제에서 중요한 점: 처음 저장한 값은 문자열 값이기 때문에 num[0] 이런 식으로 값을 불러내면 "1"형태로, int형의 정수형태가 아닌 문자열 형태로 부르는 것과 같다. 이 값을 숫자 int 형태로 바꾸어 주려면 아스키 코드를 사용해 (num[0]-48) 형태로 사용해야 한다.
코드는 다음과 같다.
'C++' 카테고리의 다른 글
[백준 알고리즘] 8958번 : OX퀴즈, c++ (0) | 2022.01.11 |
---|---|
[백준 알고리즘] 1152번 : 단어의 개수, c++ (0) | 2022.01.11 |
[백준 알고리즘] 10951번 : A+B - 4, c++ (0) | 2022.01.09 |
[백준 알고리즘] 5597번 : 과제 안 내신 분..?, c++ (0) | 2022.01.09 |
[백준 알고리즘] 11654번 : 아스키 코드, c++ (0) | 2022.01.08 |