https://school.programmers.co.kr/learn/courses/30/lessons/64065
원소 개수가 적은 항목 순으로 정렬하고,
LinkedHashSet에 1개씩 중복되지 않은 값을 넣어주면 결과를 얻을 수 있다.
문제에서 주어지는 값이 배열이 아닌 문자열이므로, 적당히 쪼개줘야 한다.
import java.util.*;
class Solution {
public int[] solution(String s) {
String[] arr = s.replaceAll("\\},\\{", "\\|")
.replaceAll("[{}]", "")
.split("\\|");
Arrays.sort(arr, (a1, a2) -> a1.length() - a2.length());
Set<Integer> answer = new LinkedHashSet();
for (String a : arr) {
String[] split = a.split(",");
for (String num : split) {
answer.add(Integer.parseInt(num));
}
}
return answer.stream().mapToInt(a -> (int)a).toArray();
}
}