문제
https://school.programmers.co.kr/learn/courses/30/lessons/131128
나의 풀이
class Solution {
public String solution(String X, String Y) {
StringBuilder result = new StringBuilder();
int[] x = { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 };
int[] y = { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 };
for (int i = 0; i < X.length(); i++) {
x[X.charAt(i) - '0'] += 1;
}
for (int i = 0; i < Y.length(); i++) {
y[Y.charAt(i) - '0'] += 1;
}
for (int i = 9; i >= 0; i--) {
for (int j = 0; j < Math.min(x[i], y[i]); j++) {
result.append(i);
}
}
String answer = result.toString();
if (answer.equals(""))
return "-1";
if (answer.startsWith("0"))
return "0";
return answer;
}
}
인덱스를 값, 데이터를 횟수로 하는 배열 x, y를 활용하여 풀었다.
String객체를 자주 변경해야 하므로 StringBuilder를 사용하였다.
'알고리즘 & 문제 > 프로그래머스' 카테고리의 다른 글
[프로그래머스] 최소 직사각형(java) (0) | 2023.02.08 |
---|---|
[프로그래머스] 나머지가 1이 되는 수 찾기(java) (0) | 2023.02.07 |
[프로그래머스] 삼총사(java) (0) | 2023.02.06 |
[프로그래머스] 콜라 문제(java) (0) | 2023.02.03 |
[프로그래머스] 옹알이(java) (0) | 2023.02.03 |