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

2024-09-30 05:14:50 发布

您现在位置:Python中文网/ 问答频道 /正文

类似于1234456654987;我们看到,我们有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

因此,在此之后,我们将得到编号为s的ask列表,以及带有值的频率。我可以进一步编码。 但是它显示的是最后一行的索引超出范围的错误,也就是问[k]+=1,我猜不出来,为什么会这样显示。请帮我做这个。 如果还有其他代码,请帮助我


Tags: 代码infordefrange解决方案askint
3条回答

试试这个:

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

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

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

作为查找最大计数并对其进行筛选的替代方法,您可以对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])
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

相关问题 更多 >

    热门问题