whatisthis?
[백준] 2908번 - 상수 (node.js) 본문
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));
'ALGORITHM > BOJ (Node.js)' 카테고리의 다른 글
[백준] 5622번 - 다이얼 (node.js) (0) | 2022.07.07 |
---|---|
[백준] 1152번 - 단어의 개수 (node.js) (0) | 2022.07.07 |
[백준] 1157번 - 단어 공부 (node.js) (0) | 2022.07.07 |
[백준] 2675번 - 문자열 반복 (node.js) (0) | 2022.07.07 |
[백준] 10809번 - 알파벳 찾기 (node.js) (0) | 2022.07.07 |