python3 实现从一个无序列表中求取连续元素之和中最大的和

介绍

今天遇到一个需求,要求从一个无序列表中求取连续元素之和中最大的和。使用python做了实现,后来想着可以作为一个小知识点分享出来,或许能在某时某刻给某位同学一些帮助。下面就直接上代码:

1、简单版

说明:

  1. 传参必须是列表,否则会抛异常
  2. 返回值为符合要求的和
def getMaxSum(li):
    # 要求计算给定列表中连续元素的和中最大的值
    sumList = []
    for i in range(0, len(li)):
        jj = i + 1
        maxIndex = len(li)
        # while jj < maxIndex+1:  # 包含单元素
        while jj < maxIndex:  # 至少两个元素
            subList = [li[i]]
            subList.extend([li[ii] for ii in range(jj, maxIndex)])
            sumList.append(sum(subList))
            maxIndex -= 1
    return max(sumList)

调用

if __name__ == '__main__':
	print('结果1:', getMaxSum([3, -4, 2, -4, -9, 8, -7]))
    print('结果2:', getMaxSum([3, 4, 2, 4, 9, 8, 7]))
    print('结果3:', getMaxSum([-3, -4, -2, -4, -9, -8, -7]))
    print('结果4:', getMaxSum([0, 0, 0, 0]))
结果
结果11
结果237
结果3-6
结果40
1、扩展版

说明:

  1. 传参必须是数字列表,否则返回-1
  2. 返回值为一个元组,第一个元素为所求的最大和,第二个元素为一个列表,列表中的是符合条件的连续元素组成的列
def getMaxSum(li):
    # 要求计算给定列表中连续元素的和中最大的值,并返回对应的元素

    # 如果传参不是列表类型或者列表元素中有非数字元素,返回False
    if not isinstance(li, list) or [x for x in li if not isinstance(x, (int, float))]:
       return False

    sumList = []
    subList = []
    targetList = []

    # 处理目标列表
    for i in range(0, len(li)):
        jj = i + 1
        maxIndex = len(li)
        # while jj < maxIndex+1:  # 包含单元素
        while jj < maxIndex:   # 至少两个元素
            temSubList = [li[i]]
            temSubList.extend([li[ii] for ii in range(jj, maxIndex)])
            temMaxSum = sum(temSubList)
            subList.append([temSubList, temMaxSum])
            sumList.append(temMaxSum)
            maxIndex -= 1

    # 获取连续元素之和中最大的值
    targetSum = max(sumList)

    # 获取符合要求的元素的列表
    for item in subList:
        temSum = item[1]
        if temSum == targetSum:
            targetList.append(item[0])

    # 返回元组,第一个元素为所求的最大和,第二个元素为一个列表,列表中的是符合条件的连续元素组成的列表,可能有多个
    return targetSum, targetList

调用

if __name__ == '__main__':
	print('结果1:', getMaxSum([3, -4, 2, -4, -9, 8, -7]))
    print('结果2:', getMaxSum([3, 4, 2, 4, 9, 8, 7]))
    print('结果3:', getMaxSum([-3, -4, -2, -4, -9, -8, -7]))
    print('结果4:', getMaxSum([0, 0, 0, 0]))
    print('结果5:', getMaxSum([3, -4, 2, -4, '-9', 8, -7]))
结果
结果1(1, [[3, -4, 2], [8, -7]])
结果2(37, [[3, 4, 2, 4, 9, 8, 7]])
结果3(-6, [[-4, -2], [-2, -4]])
结果4(0, [[0, 0, 0, 0], [0, 0, 0], [0, 0], [0, 0, 0], [0, 0], [0, 0]])
结果5False
### 回答1: 可以使用列表推导式和 set() 函数来删除数组多个相同元素。具体代码如下: ```python arr = [1, 2, 3, 2, 4, 3, 5, 6, 5] arr = list(set([i for i in arr])) print(arr) ``` 输出结果为:[1, 2, 3, 4, 5, 6] ### 回答2: 在Python,可以使用列表推导式或集合(set)来删除数组的多个相同元素。 1. 使用列表推导式: 列表推导式是一种构建新列表的方法,可以通过遍历原始数组,并使用条件判断来选择要保留的元素,从而实现删除重复元素的效果。 例如,假设原始数组为arr,要删除的元素为value,可以使用以下代码进行删除操作: ```python arr = [1, 2, 3, 2, 4, 3, 5] value = 2 new_arr = [x for x in arr if x != value] ``` 这段代码会生成一个新的列表new_arr,其排除了与value相等的元素。输出结果为[1, 3, 4, 3, 5]。 2. 使用集合(set): 集合是一种无序且唯一的对象集合,可以利用这个特性来删除数组的重复元素。将数组转换为集合,然后再转换回列表即可。 例如,假设原始数组为arr,可以使用以下代码进行删除操作: ```python arr = [1, 2, 3, 2, 4, 3, 5] new_arr = list(set(arr)) ``` 上述代码会首先将arr转换为集合,然后再转换为列表。输出结果为[1, 2, 3, 4, 5]。 需要注意的是,上述方法会打乱元素的原始顺序,如果要保持顺序不变,可以使用有序集合来进行操作,例如使用collections模块的OrderedDict()函数。 综上所述,可以使用列表推导式或集合来删除数组的多个相同元素。 ### 回答3: 在Python,可以使用循环结合删除方法来删除数组的多个相同元素。下面是一个示例代码: ```python def remove_duplicates(arr): # 用一个列表来存储去重后的元素 result = [] # 遍历数组的每一个元素 for elem in arr: # 如果元素不在结果列表,则将其添加到结果列表 if elem not in result: result.append(elem) return result # 示例用法 my_array = [1, 2, 3, 4, 3, 2, 1, 5, 6, 5, 4] result_array = remove_duplicates(my_array) print(result_array) ``` 运行结果为: ``` [1, 2, 3, 4, 5, 6] ``` 在上述代码,`remove_duplicates`函数接受一个数组作为输入,并返回一个去重后的新数组。它通过遍历输入数组的每一个元素,判断该元素是否已经存在于结果列表,若不存在则将该元素添加到结果列表。最后,函数返回结果列表。 需要注意的是,这种方法删除的是连续出现的相同元素,如果需要删除所有相同的元素,可以使用`collections.Counter`模块来完成。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值