본문 바로가기

코딩테스트/programmers

튜플

https://school.programmers.co.kr/learn/courses/30/lessons/64065

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

 

원소 개수가 적은 항목 순으로 정렬하고,

 

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();
    }
}

 

'코딩테스트 > programmers' 카테고리의 다른 글

프로세스  (0) 2023.10.12
기능개발  (1) 2023.10.12
의상  (0) 2023.10.10
캐시  (0) 2023.10.06
행렬의 곱셈  (0) 2023.10.06