https://www.acmicpc.net/problem/2908
1. 문제
💡 문제
상근이의 동생 상수는 수학을 정말 못한다. 상수는 숫자를 읽는데 문제가 있다. 이렇게 수학을 못하는 상수를 위해서 상근이는 수의 크기를 비교하는 문제를 내주었다. 상근이는 세 자리 수 두 개를 칠판에 써주었다. 그 다음에 크기가 큰 수를 말해보라고 했다.
상수는 수를 다른 사람과 다르게 거꾸로 읽는다. 예를 들어, 734와 893을 칠판에 적었다면, 상수는 이 수를 437과 398로 읽는다. 따라서, 상수는 두 수중 큰 수인 437을 큰 수라고 말할 것이다.
두 수가 주어졌을 때, 상수의 대답을 출력하는 프로그램을 작성하시오.
💡 입력
첫째 줄에 상근이가 칠판에 적은 두 수 A와 B가 주어진다. 두 수는 같지 않은 세 자리 수이며, 0이 포함되어 있지 않다.
💡 출력
첫째 줄에 상수의 대답을 출력한다.
2. 풀이
#include <stdio.h>
int main(){
int i, j, count = 0;
// 동일한 자릿수의 두 값을 입력받기 위해 2차원 배열 선언
int num [2][3] = {0,};
// 2차원 배열의 각 자리에 숫자 하나씩 값을 저장
for (i = 0 ; i < 2 ; i++){
for (j = 0 ; j < 3; j++){
scanf("%1d", &num[i][j]);
}
}
// 문제에서 숫자를 뒤집어 비교하라고 하였기에, 역수를 비교해서 그 값이 크거나 작다면 count 값을 저장하고
// 값이 같다면 이전 인덱스의 값들을 서로 비교
for (i = 2 ; i >= 0 ; i--){
if (num [0][i] > num[1][i]){
count = 0;
break;
}
else if (num [0][i] < num[1][i]){
count = 1;
break;
}
}
for (i = 2 ; i >= 0 ; i--) printf("%d", num[count][i]);
}
3. 메모
어... 역시나 "이 답이 최선입니까?" 하고 물어보시면... 저....저의 대답은...
"네니요..?"
'프로그래밍 > 백준 알고리즘' 카테고리의 다른 글
[C] 크로아티아 알파벳 (백준 알고리즘 2941번) (0) | 2021.08.11 |
---|---|
[C] 다이얼 (백준 알고리즘 5622번) (0) | 2021.07.26 |
[C] 단어의 개수 (백준 알고리즘 1152번) (0) | 2021.07.24 |
[C] 단어공부 (백준 알고리즘 1157번) (0) | 2021.07.23 |
[C] 문자열 반복 (백준 알고리즘 2675번) (0) | 2021.07.23 |