본문 바로가기
알고리즘 Node.js

백준 2908문제. 상수

by 반갑조? 2025. 3. 20.

문제

문제: 상근이의 동생 상수는 수학을 정말 못한다. 상수는 숫자를 읽는데 문제가 있다. 이렇게 수학을 못하는 상수를 위해서 상근이는 수의 크기를 비교하는 문제를 내주었다. 상근이는 세 자리 수 두 개를 칠판에 써주었다. 그 다음에 크기가 큰 수를 말해보라고 했다. 상수는 수를 다른 사람과 다르게 거꾸로 읽는다. 예를 들어, 734와 893을 칠판에 적었다면, 상수는 이 수를 437과 398로 읽는다. 따라서, 상수는 두 수중 큰 수인 437을 큰 수라고 말할 것이다.

두 수가 주어졌을 때, 상수의 대답을 출력하는 프로그램을 작성하시오.

입력: 첫째 줄에 상근이가 칠판에 적은 두 수 A와 B가 주어진다. 두 수는 같지 않은 세 자리 수이며, 0이 포함되어 있지 않다.

출력: 첫째 줄에 상수의 대답을 출력한다.

예제 입력: 734 893  또는  221 231  또는  839 237

예제 출력: 437         또는  132         또는 938

 

풀이

const fs = require('fs');
const input = fs.readFileSync(0, 'utf-8').trim().split(' ');

let result = [];

for(let i = 0; i<input.length; i++){
  const Num = input[i].split('').reverse().join('');
  result.push(Number(Num));
}

console.log(Math.max(result[0], result[1]));

 

풀이 해석

1. fs.readFileSync(0, 'utf-8')을 사용하여 입력을 받고, 공백(' ')을 기준으로 나누어 배열(input)에 저장한다.
2. for문을 사용하여 각 숫자를 뒤집는다. (split('') → reverse() → join(''))
3. 뒤집은 숫자를 Number()로 변환하여 배열(result)에 저장한다.
4. Math.max()를 사용하여 더 큰 숫자를 출력한다.

 

더 알아보기

1. 최적코드

const fs = require('fs');
const input = fs.readFileSync(0, 'utf-8').trim().split(' ');

const reversedNumbers = input.map(num => Number(num.split('').reverse().join('')));
console.log(Math.max(...reversedNumbers));

- fs.readFileSync(0, 'utf-8')을 사용하여 입력을 받고, 공백(' ')을 기준으로 나누어 배열(input)에 저장한다.
- map()을 사용하여 각 숫자를 뒤집고 Number()로 변환한다. (split('') → reverse() → join(''))
- Math.max()를 사용하여 더 큰 숫자를 출력한다.

 

2. reduce()를 사용하면 안되는 이유

- const Num = input[i].split('').reduce((arr, acr) => acr + arr, '');  는 acr+arr로 되어있는데, 이렇게 하면 배열을 거꾸로 만드는게 아니라 각 문자들이 누적되는 순서가 뒤섞일 수 있다.

- 그러므로 문자열을 배열로 변환(split('')) 후에 배열을 뒤집고(reverse()) 다시 문자열로 변환(join(''))을 사용해서 거꾸로 만들어야 한다.