Q10轮盘的最大值

本文探讨了在欧式和美式轮盘规则下,寻找连续n个数和最大值的算法实现。通过动态更新和比较两种规则下的最大和,找出满足特定条件的n值。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

E:/GitHub/suanfaquti/Q10轮盘的最大值.py
''' 
当1<n<37时,求连续n个数的和最大的情况下满足“欧式规则下和小于美式规则的和”的n
分析
新加入的数字减去第一个的值加上原来的sum就是新sum
'''

o=[0, 32, 15, 19, 4, 21, 2, 25, 17, 34, 6, 27, 13, 36, 11, 30, 8, 23, 10,
   5, 24, 16, 33, 1, 20, 14, 31, 9, 22, 18, 29, 7, 28, 12, 35, 3, 26]
m=[0, 28, 9, 26, 30, 11, 7, 20, 32, 17, 5, 22, 34, 15, 3, 24, 36, 13, 1,
   0, 27, 10, 25, 29, 12, 8, 19, 31, 18, 6, 21, 33, 16, 4, 23, 35, 14, 2 ]
print(len(o),len(m))        #37,38


def getmax(n,a):
    l=len(a)
    maxsum=current=sum(a[:n])
    for i in range(l-1):
        current=current+a[(i+n)%l]-a[i%l]
        maxsum=max(maxsum,current)
        #print(i,a[i],maxsum,current)
    return maxsum

res=[]
for i in range(2,37):    
    a,b=getmax(i,o),getmax(i,m)
    if a<b:
       res.append((i,a,b))

print(res,len(res))
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值