두 정수
X
,Y
의 임의의 자리에서 공통으로 나타나는 정수 k(0 ≤ k ≤ 9)들을 이용하여 만들 수 있는 가장 큰 정수를 두 수의 짝꿍이라 합니다(단, 공통으로 나타나는 정수 중 서로 짝지을 수 있는 숫자만 사용합니다).X
,Y
의 짝꿍이 존재하지 않으면, 짝꿍은 -1입니다.X
,Y
의 짝꿍이 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 한 개는 짝 지을 수 없습니다.)
두 정수
X
,Y
가 주어졌을 때,X
,Y
의 짝꿍을 return하는 solution 함수를 완성해주세요.
X
, Y
의 길이(자릿수) ≤ 3,000,000입니다.X
, Y
는 0으로 시작하지 않습니다.X
, Y
의 짝꿍은 상당히 큰 정수일 수 있으므로, 문자열로 반환합니다.X | Y | result |
---|---|---|
"100" | "2345" | "-1" |
"100" | "203045" | "0" |
"100" | "123450" | "10" |
"12321" | "42531" | "321" |
"5525" | "1255" | "552" |
입출력 예 #1
X
, Y
의 짝꿍은 존재하지 않습니다. 따라서 "-1"을 return합니다.입출력 예 #2
X
, Y
의 공통된 숫자는 0으로만 구성되어 있기 때문에, 두 수의 짝꿍은 정수 0입니다. 따라서 "0"을 return합니다.입출력 예 #3
X
, Y
의 짝꿍은 10이므로, "10"을 return합니다.입출력 예 #4
X
, Y
의 짝꿍은 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뿐일 때의 처리를 해주고 그 외에는 해당 숫자들을 내림차순으로 정렬하여 리턴하였다.