소정이는 어떤 숫자에서 k개의 수를 뽑았을 때 가장 큰 수를 찾는 놀이를 하고 있습니다.
예를 들어, 숫자 1723에서 두 개의 수를 뽑으면 [17, 12, 13, 72, 73, 23]을 만들 수 있습니다.
이 중 가장 큰 수는 73입니다.
위 예시처럼 어떤 수 n에서 k개의 수를 선택하여 만들 수 있는 수 중에서 가장 큰 수를 찾아 주세요.
/**
* 어떤 수 N에서 K개의 수를 선택하여 만들 수 있는 수 중에서
*
* 가장 큰 수를 반환하는 함수
* @param {Number} N
* @param {Number} K
* @returns {Number} 가장 큰 수
*/
function pickNumber(N, K) {
return parseInt(
N.toString() // 문자열로 변환
.split('') // 각 문자별로 split
.map(Number) // 숫자로 변환
.sort((a, b) => b - a) // 내림차순으로 정렬
.slice(0, K) // 맨 앞 K개만 slice
.join('') // 붙여줌
); // 정수로 변환
}
const N = 1723;
const K = 2;
const result = pickNumber(N, K);
console.log(result);
'PS > 제코베 JS 100제' 카테고리의 다른 글
제코베 JS 100제 / 86 / 회전 초밥 (0) | 2022.09.29 |
---|---|
제코베 JS 100제 / 85 / 숫자놀이 (0) | 2022.09.29 |
제코베 JS 100제 / 83 / 수학 괄호 파싱 2 (0) | 2022.09.29 |
제코베 JS 100제 / 82 / 수학 괄호 파싱 (0) | 2022.09.25 |