用于查找 Python 中最频繁元素的频率的程序
假设我们有一个数组nums和另一个值k。在一次操作中,我们可以选择一个nums索引并将该索引处的元素增加1。我们必须在执行最多k次操作后找到元素的最大可能频率。
所以,如果输入像nums=[8,3,6],k=9,那么输出将是3,因为我们可以更新3by5,6by2,使其成为[8,8,8]所以经过7次操作后,我们的最大频率为3。
示例
让我们看看以下实现以获得更好的理解-
def solve(nums, k): nums.sort() left = 0 right = 1 while right < len(nums): k -= (nums[right] - nums[right-1]) * (right - left) if k < 0: k += nums[right] - nums[left] left += 1 right += 1 return right - left nums = [8,3,6] k = 9 print(solve(nums, k))
输入
[8,3,6], 9输出结果
3