leetcode1481. Least Number of Unique Integers after K Removals

Posted seyjs

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了leetcode1481. Least Number of Unique Integers after K Removals相关的知识,希望对你有一定的参考价值。

题目如下:

Given an array of integers arr and an integer k. Find the least number of unique integers after removing exactly k elements.

Example 1:

Input: arr = [5,5,4], k = 1
Output: 1
Explanation: Remove the single 4, only 5 is left.

Example 2:

Input: arr = [4,3,1,1,3,3,2], k = 3
Output: 2
Explanation: Remove 4, 2 and either one of the two 1s or three 3s. 1 and 3 will be left. 

Constraints:

  • 1 <= arr.length <= 10^5
  • 1 <= arr[i] <= 10^9
  • 0 <= k <= arr.length

解题思路:贪心算法, 从出现次数最少的元素删起,然后是次最少。

代码如下:

class Solution(object):
    def findLeastNumOfUniqueInts(self, arr, k):
        """
        :type arr: List[int]
        :type k: int
        :rtype: int
        """
        dic = {}
        for i in arr:
            dic[i] = dic.setdefault(i,0) + 1
        pair = []
        for key,val in dic.iteritems():
            pair.append((key,val))

        def cmpf(item1,item2):
            return item1[1] - item2[1]

        pair.sort(cmp=cmpf)

        while len(pair) > 0 and k > 0:
            key,val = pair.pop(0)
            if k >= val:
                k -= val
            else:
                pair.append((key,val))
                break

        return len(pair)

 

以上是关于leetcode1481. Least Number of Unique Integers after K Removals的主要内容,如果未能解决你的问题,请参考以下文章

LeetCode 395. Longest Substring with At Least K Repeating Characters

[LeetCode] Largest Number At Least Twice of Others

[leetcode-748-Largest Number At Least Twice of Others]

Leetcode: Longest Substring with At Least K Repeating Characters

LeetCode-Longest Substring with At Least K Repeating Characters

[LeetCode] 747. Largest Number At Least Twice of Others_Easy