在 Python 中找到 O(n) 时间和 O(1) 额外空间的最大重复数
假设我们有一个大小为n的数组,如果数组中的元素在0到k-1的范围内。其中k表示为正整数且k<=n。我们必须找到这个数组中的最大重复数。
因此,如果输入类似于k=8且A=[3,4,4,6,4,5,2,8],那么输出将为4。
在线示例
让我们看看以下实现以获得更好的理解-
def get_max_repeating(A, k):
n = len(A)
for i in range(n):
A[A[i]%k] += k
max_val = A[0]
result = 0
for i in range(1, n):
if A[i] > max_val:
max_val = A[i]
result = i
return result
A = [3, 4, 4, 6, 4, 5, 2, 8]
k = 8
print(get_max_repeating(A, k))输入
[3, 4, 4, 6, 4, 5, 2, 8], 8输出结果
4
热门推荐
10 浪漫的未来祝福语简短
11 茶人生日祝福语简短
12 对航母的祝福语简短
13 横幅家庭生日祝福语简短
14 给宝贝开学祝福语简短
15 白日庆典祝福语简短英语
16 思念丈夫祝福语简短的话
17 买房的祝福语高级简短
18 姥爷生日诗句祝福语简短