[프로그래머스 Lv1] 숫자 짝궁 - (Javascript)

eeeyooon·2024년 1월 16일
0

숫자 짝궁

문제 링크

📩 문제 설명

두 정수 XY의 임의의 자리에서 공통으로 나타나는 정수 k(0 ≤ k ≤ 9)들을 이용하여 만들 수 있는 가장 큰 정수를 두 수의 짝꿍이라 합니다(단, 공통으로 나타나는 정수 중 서로 짝지을 수 있는 숫자만 사용합니다). XY의 짝꿍이 존재하지 않으면, 짝꿍은 -1입니다. XY의 짝꿍이 0으로만 구성되어 있다면, 짝꿍은 0입니다.

예를 들어, X = 3403이고 Y = 13203이라면, X와 Y의 짝꿍은 X와 Y에서 공통으로 나타나는 3, 0, 3으로 만들 수 있는 가장 큰 정수인 330입니다. 다른 예시로 X = 5525이고 Y = 1255이면 X와 Y의 짝꿍은 X와 Y에서 공통으로 나타나는 2, 5, 5로 만들 수 있는 가장 큰 정수인 552입니다(X에는 5가 3개, Y에는 5가 2개 나타나므로 남는 5 한 개는 짝 지을 수 없습니다.)

두 정수 XY가 주어졌을 때, XY의 짝꿍을 return하는 solution 함수를 완성해주세요.

제한 사항

  • 3 ≤ XY의 길이(자릿수) ≤ 3,000,000입니다.
  • XY는 0으로 시작하지 않습니다.
  • XY의 짝꿍은 상당히 큰 정수일 수 있으므로, 문자열로 반환합니다.

입출력 예

XYresult
"100""2345""-1"
"100""203045""0"
"100""123450""10"
"12321""42531""321"
"5525""1255""552"

입출력 예 #1

  • XY의 짝꿍은 존재하지 않습니다. 따라서 "-1"을 return합니다.

입출력 예 #2

  • XY의 공통된 숫자는 0으로만 구성되어 있기 때문에, 두 수의 짝꿍은 정수 0입니다. 따라서 "0"을 return합니다.

입출력 예 #3

  • XY의 짝꿍은 10이므로, "10"을 return합니다.

입출력 예 #4

  • XY의 짝꿍은 321입니다. 따라서 "321"을 return합니다.

입출력 예 #5

  • 지문에 설명된 예시와 같습니다.

제출 답안

function solution(X, Y) {
    let answer = '';
    
    X = X.split("");
    Y = Y.split("")
    
    for (let i=0; i<=9; i++) {
        const accX = X.filter(n => +n === i).length;
        const accY = Y.filter(n => +n === i).length;
        
        answer += i.toString().repeat(Math.min(accX,accY))
    }
    
    if (answer.length === 0) return "-1";
    if (+answer === 0) return "0";
    
    return answer.split("").sort((a,b) => +b - +a).join("");
    
}

답안 설명

X와 Y에 들어가는 숫자는 0에서 9까지의 정수이기 때문에 for문을 사용하여 X와 Y의 0부터 9까지의 숫자가 각각 몇개가 들어가는지 체크하고, 그 중 가장 적은 개수만큼 해당 숫자를 반복해서 answer에 넣었다. 최종적으로 for문이 끝났을 때 answer에는 두 X와 Y의 공통된 정수가 최소 숫자만큼 들어가있다. (만약 둘 중 하나엔 없는 숫자라면 가장 적은 개수가 0이므로 answer엔 들어가지 않는다.)

이후 공통된 숫자가 없을때와 그 공통된 숫자가 0뿐일 때의 처리를 해주고 그 외에는 해당 숫자들을 내림차순으로 정렬하여 리턴하였다.



0개의 댓글