为了账号安全,请及时绑定邮箱和手机立即绑定

Python Logic,用于查找满足条件的子列表的总和

Python Logic,用于查找满足条件的子列表的总和

莫回无 2022-08-25 13:46:58
我需要找到 和 之间的列表元素的总和。-1-1我尝试了这个解决方案,但它将元素添加到.你能帮我一个更好的逻辑吗?1,2,31,1,1,1lis = [1,2,3,4,-1,1,1,1,1,-1,1,2,3]sum = 0newlis = []    for i in range(0,len(lis)-1):        if lis[i] == -1:            while i+1 < len(lis) and lis[i+1]!=-1:                sum = sum+lis[i+1]                i = i+1print(sum)
查看完整描述

4 回答

?
LEATH

TA贡献1936条经验 获得超6个赞

您可以使用:


idx = [i for i, v in enumerate(lis, 1) if v == -1]

print(sum(lis[idx[0]:idx[1]-1]))

# 4


查看完整回答
反对 回复 2022-08-25
?
FFIVE

TA贡献1797条经验 获得超6个赞

下面是一个无需工作的示例lambda


lis = [1,2,3,4,-1,1,1,1,1,-1,1,2,3]


first = lis.index(-1) + 1

second = lis[first:].index(-1) + first


result = sum(lis[first:second])


查看完整回答
反对 回复 2022-08-25
?
眼眸繁星

TA贡献1873条经验 获得超9个赞

一种方法是,您可以创建一个布尔标志,当您看到 -1 时,该标志设置为 true,并在看到第二个 -1(或中断)时将其设置回 false。如果标志为真,则将数字相加。


lis = [1,2,3,4,-1,1,1,1,1,-1,1,2,3]

sum = 0

flag = False;

for i in range(len(lis)):

    if not flag:

        if lis[i] == -1:

            flag = True

    elif lis[i] == -1:

        flag = False #this line could be omitted

        break

    else:

        sum += lis[i]

print(sum)


查看完整回答
反对 回复 2022-08-25
?
蛊毒传说

TA贡献1895条经验 获得超3个赞

您可以使用 来查找第一个 -1。它还提供了第二个参数,用于从何处开始搜索,因此您也可以使用它来查找第二个 -1。然后只需获取它们之间的切片并求和即可。lis.index


>>> start = lis.index(-1) + 1

>>> stop = lis.index(-1, start)

>>> sum(lis[start:stop])

4


查看完整回答
反对 回复 2022-08-25
  • 4 回答
  • 0 关注
  • 89 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号