728x90
programmers.co.kr/learn/courses/30/lessons/42746
코딩테스트 연습 - 가장 큰 수
0 또는 양의 정수가 주어졌을 때, 정수를 이어 붙여 만들 수 있는 가장 큰 수를 알아내 주세요. 예를 들어, 주어진 정수가 [6, 10, 2]라면 [6102, 6210, 1062, 1026, 2610, 2106]를 만들 수 있고, 이중 가장 큰
programmers.co.kr
정렬 방법을 고민하느라 조금 헤맸던 문제이다
Comparator를 이용해 쉽게 풀수 있던 문제였다
전 배열과 현재 배열을 String 형태로 순서를 서로 바꿔 더해 더 큰 값이 앞으로 오도록 정렬하는 방식으로 풀었다
import java.util.*;
class Solution {
public String solution(int[] numbers) {
String answer = "";
String[] sNumbers = new String[numbers.length];
for(int i = 0;i<numbers.length;i++){
sNumbers[i] = Integer.toString(numbers[i]);
}
if(sNumbers[numbers.length-1].equals("0")){return "0";}
Arrays.sort(sNumbers, new Comparator<String>(){
@Override
public int compare(String a, String b) {
return (b+a).compareTo(a+b);
}
});
for(int i =0;i<numbers.length;i++){
answer+=sNumbers[i];
}
return answer;
}
}728x90
'프로그래머스 코딩테스트 연습 > Level2' 카테고리의 다른 글
| [프로그래머스][JAVA] 괄호 회전하기 (0) | 2021.05.06 |
|---|---|
| [프로그래머스][JAVA] 전화번호 목록 (0) | 2021.05.06 |
| [프로그래머스][JAVA] 튜플 (0) | 2021.05.06 |
| [프로그래머스][JAVA] 카카오프렌즈 컬러링북 (0) | 2021.05.06 |
| [프로그래머스][JAVA] 더 맵게 (0) | 2021.05.06 |