对于给定的 4 个数字作为函数的参数,我必须找到所有数字组合最大频率的数字?



像1234,4566,654,987;我们看到,我们有4和6,频率为3。因此,我们将接收输出为 6,因为它是较大的输出。 因此,我认为作为解决方案的代码是:

def MaxDigit(input1,input2,input3,input4):
arr=[input1,input2,input3,input4]
k=0
for i in range(1,10):
ask=[0]*i
for j in range(0,4):
while arr[j]!=0:
k=int(arr[j]%10)
arr[j]=int(arr[j]/10)
ask[k]+=1

因此,在此之后,我们将获得带有no.s作为索引和频率作为值的询问列表。我可以进一步编码。 但是它显示最后一行的索引超出范围错误,即 ask[k]+=1,我无法猜测,为什么它这样显示。请帮我解决这个问题。 如果也可以有替代代码,请帮助我。

input = [234,4566,654,987]
digits = [int(n) for num in input for n in str(num)] # extracts each digit separately into a list as in [2, 3, 4, 4, 5, 6, 6, 6, 5, 4, 9, 8, 7]

生成频率字典并根据您的条件对字典进行排序,首先根据值的降序,然后根据降序或键。

digit_count = {i:digits.count(i) for i in set(digits)} 
digit_count_sorted = sorted(digit_count.items(), key=lambda x: (-x[1], -x[0]))
digit_count_sorted[0][0] #prints the answer 6

您可以将其实现为函数:

def MaxDigit(input):
digits = [int(n) for num in input for n in str(num)]
digit_count = {i:digits.count(i) for i in set(digits)} 
digit_count_sorted = sorted(digit_count.items(), key=lambda x: (-x[1], -x[0]))
return digit_count_sorted[0][0]
print(MaxDigit([234,4566,654,987])

输出:

6

试试这个:

def MaxDigit(input1,input2,input3,input4):
s = '{}{}{}{}'.format(input1,input2,input3,input4)
maxCount = 0
maxDigit = 0
for digit in range(10):
count = s.count(str(digit))
if maxCount <= count:
maxCount = count
maxDigit = digit
return maxDigit

实现这一点的一种方法是使用Counter,将所有数字转换为字符串并计算数字。然后,您可以从计数器中找到最大计数,并返回具有该计数的最大值:

from collections import Counter
def MaxDigit(*args):
counts = Counter(''.join(str(a) for a in args))
maxcount = counts.most_common(1)[0][1]
return int(max(v for v, c in counts.items() if c == maxcount))
print(MaxDigit(1234,4566,654,987))

输出:

6

作为查找最大计数并对其进行筛选的替代方法,您可以按 count 和 key 降序对Counter进行排序,然后返回第一个值的键:

def MaxDigit(*args):
counts = Counter(''.join(str(a) for a in args))
counts = sorted(counts.items(), key=lambda x:(-x[1], -int(x[0])))
return int(counts[0][0])

相关内容

  • 没有找到相关文章

最新更新