ALGORITHM/BOJ (Node.js)

[백준] 2908번 - 상수 (node.js)

thisisyjin 2022. 7. 7. 16:06

JavaScript

문제

상근이의 동생 상수는 수학을 정말 못한다. 상수는 숫자를 읽는데 문제가 있다. 이렇게 수학을 못하는 상수를 위해서 상근이는 수의 크기를 비교하는 문제를 내주었다. 상근이는 세 자리 수 두 개를 칠판에 써주었다. 그 다음에 크기가 큰 수를 말해보라고 했다.

상수는 수를 다른 사람과 다르게 거꾸로 읽는다. 예를 들어, 734와 893을 칠판에 적었다면, 상수는 이 수를 437과 398로 읽는다. 따라서, 상수는 두 수중 큰 수인 437을 큰 수라고 말할 것이다.

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

입력

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

출력

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

예제

입력

734 893

출력

437

내 코드

const input = require('fs').readFileSync('/dev/stdin').toString().split(' ');

// const input = ['734', '893'];
const [num1, num2] = input;

const number1 = num1.split('').reverse().join('');
const number2 = num2.split('').reverse().join('');

console.log(Math.max(+number1, +number2));

배열을 이용하여 reverse()를 한 후 join('')으로 합쳐준다.

실행 결과

120ms / 9332KB


다른 코드

입력은 두 세자리 수라고 했으니, 아래와 같이도 풀 수 있다. (성능은 위의 코드가 더 좋다!)

const input = require('fs').readFileSync('/dev/stdin').toString().split(' ');

const [num1, num2] = input;

const number1 = num1.split('').map((v, i) => num1[2-i]).join('');
const number2 = num2.split('').map((v, i) => num2[2-i]).join('');

console.log(Math.max(+number1, +number2));