用于查找 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