[프로그래머스] level2. 귤 고르기

홈런볼·2023년 8월 16일
0

프로그래머스

목록 보기
33/36

문제링크

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

문제설명

경화는 과수원에서 귤을 수확했습니다. 경화는 수확한 귤 중 'k'개를 골라 상자 하나에 담아 판매하려고 합니다. 그런데 수확한 귤의 크기가 일정하지 않아 보기에 좋지 않다고 생각한 경화는 귤을 크기별로 분류했을 때 서로 다른 종류의 수를 최소화하고 싶습니다.

예를 들어, 경화가 수확한 귤 8개의 크기가 [1, 3, 2, 5, 4, 5, 2, 3] 이라고 합시다. 경화가 귤 6개를 판매하고 싶다면, 크기가 1, 4인 귤을 제외한 여섯 개의 귤을 상자에 담으면, 귤의 크기의 종류가 2, 3, 5로 총 3가지가 되며 이때가 서로 다른 종류가 최소일 때입니다.

경화가 한 상자에 담으려는 귤의 개수 k와 귤의 크기를 담은 배열 tangerine이 매개변수로 주어집니다. 경화가 귤 k개를 고를 때 크기가 서로 다른 종류의 수의 최솟값을 return 하도록 solution 함수를 작성해주세요.

제한사항

  • 1 ≤ k ≤ tangerine의 길이 ≤ 100,000
  • 1 ≤ tangerine의 원소 ≤ 10,000,000

입출력

ktangerineresult
6[1, 3, 2, 5, 4, 5, 2, 3]3
4[1, 3, 2, 5, 4, 5, 2, 3]2
2[1, 1, 1, 1, 2, 2, 2, 3]1

로직

  1. 귤의 크기별 갯수를 새기 위해서 map을 선언 한 후 map에 귤의 크기와 갯수를 저장한다
  2. 귤의 갯수가 많은 크기 부터 담아야 하므로 귤의 갯수를 내림차순 한다
  3. 내림차순 정렬한 list를 돌면서 담아야될 큰 갯수만큼 담고 귤의 종류 최소값을 체크하는 변수를 증가시킨다

코드

import java.util.*;

class Solution {
    public int solution(int k, int[] tangerine) {
        int answer = 0;
        Map<Integer,Integer> map = new HashMap<>();
        for (int t : tangerine) {
            map.put(t, map.getOrDefault(t, 0) + 1);
        }
        List<Integer> keySet = new ArrayList<>(map.values());
        Collections.sort(keySet,Collections.reverseOrder());
        for(int s:keySet){
            k-=s;
            answer++;
            if(k<1) return answer;
        }
        return answer;
    }
}

시간복잡도

O(n)

정확성 테스트

0개의 댓글

Powered by GraphCDN, the GraphQL CDN