728x90
반응형
1. 문제
programmers.co.kr/learn/courses/30/lessons/42746?language=java
코딩테스트 연습 - 가장 큰 수
0 또는 양의 정수가 주어졌을 때, 정수를 이어 붙여 만들 수 있는 가장 큰 수를 알아내 주세요. 예를 들어, 주어진 정수가 [6, 10, 2]라면 [6102, 6210, 1062, 1026, 2610, 2106]를 만들 수 있고, 이중 가장 큰
programmers.co.kr
2. 풀이
- 처음에 푼 소스는 permutation으로 구하였다. 하지만 런타임에러..
- 순열로 풀면 모든 경우의 수를 찾기 때문에 그런거 같다
- Comparator를 활용하여 풀었다
- 0이 처음에 나오면 예외처리를 했다.
3. 코드
import java.util.*;
class Solution {
public String solution(int[] numbers) {
//permutation으로는 안풀림. 런타임에러 나옴.
//0,0,0,0 일때 답은 0 으로 출력되어야 한다.
String answer = "";
String[]arr = new String[numbers.length];
for(int i =0; i<numbers.length;i++){
arr[i] = String.valueOf(numbers[i]);
}
Arrays.sort(arr, new Comparator<String>() {
@Override
public int compare(String o1, String o2) {
return (o2+o1).compareTo(o1+o2);
}
});
for(int i =0; i<arr.length;i++){
answer+=arr[i];
}
if(answer.charAt(0)=='0') return "0";
return answer;
}
}
반응형
반응형
'알고리즘 > 프로그래머스' 카테고리의 다른 글
| [프로그래머스 Lv2] 더 맵게(Java) (0) | 2021.01.08 |
|---|---|
| [프로그래머스 Lv2] 괄호 변환(Java) (0) | 2021.01.07 |
| [프로그래머스 Lv2] 주식가격(Java) (0) | 2021.01.06 |
| [프로그래머스 Lv2] 삼각 달팽이(Java) (0) | 2021.01.06 |
| [프로그래머스 Lv2] 멀쩡한 사각형(Java) (0) | 2021.01.06 |