Binary Journey

[프로그래머스] 정수 내림차순으로 배치하기 본문

프로그래머스/level 1

[프로그래머스] 정수 내림차순으로 배치하기

binaryJournalist 2021. 8. 9. 01:57
반응형

 

출처: 프로그래머스 코딩 테스트 연습, https://programmers.co.kr/learn/challenges

 

 

 

** Javascript

 

 

1) 첫번째로 제출한 풀이다.

function solution(n) {
    return parseInt(n.toString().split("").sort((a,b) => b-a).join(""));
}

 

2) 다음 풀이도 가능하다.

 

function solution(n) {
    return parseInt(n.toString().split("").sort().reverse().join(""));
}

 

sort() 메소드와 reverse() 의 경우 기본적으로 string 을 다룬다.

숫자 정렬의 경우 오름차순은 (a, b) => a - b 내림차순은 (a, b) => b- a 로 조건을 넣어줘야 한다.

 

 

3) 더 간단한 경우는

 

function solution(n) {
    return +(n.toString().split("").sort().reverse().join(""));
}

이렇게 하면 된다.

 

 

javascript 에서 +문자열 은 문자열을 숫자로 변환해주고 숫자+ "" 은 숫자를 문자열로 변환해준다.

문자열*1 의 경우도 문자열을 숫자로 변환해준다.

 

 

 

사실 숫자를 문자로 변환하여 정렬할 경우 연산 속도가 느리다.

 

아래는 문자열로 변환하지 않고 숫자로만 연산하여 정렬한 다른 사람의 풀이다.

 

function solution(n) {
    var nums =[];
    do{
        nums.push(n%10);
        n=Math.floor(n/10);
    } while(n>0)

    return nums.sort((a,b)=>b-a).join('')*1;
}

 

 

 

 

 

** Java

 

 

import java.util.*;
class Solution {
    public long solution(long n) {
        String[] arr = Long.toString(n).split("");
        Arrays.sort(arr, Collections.reverseOrder());
        return Long.parseLong(String.join("", arr));
    }
}

 

 

 

 

** Python

 

 

 

1)

 

def solution(n):
    nums = []
    while (n > 0):
        nums.append(str(n % 10))
        n = n // 10
    return int("".join(sorted(nums, reverse=True)))

 

굳이 숫자 -> string -> 숫자 이럴 거면  그냥 문자열 정렬으로만 할 걸 그랬다.

 

 

 

2)

 

def solution(n):
    nums = list(str(n))
    return int("".join(sorted(nums, reverse=True)))

 

다시 고치면 이렇게 된다.

반응형