力扣1588 所有奇数长度子集组的和(21.3.9)

力扣1588 所有奇数长度子集组的和

题目描述:

给出一个正整数数组arr,计算所有可能的奇数长度子数组的和。

子数组定义:原数组中的一个连续子序列

涉及内容数组

示例

输入:arr = [1,4,2,5,3]
输出:58
解释:所有奇数长度子数组和它们的和为:
[1] = 1
[4] = 4
[2] = 2
[5] = 5
[3] = 3
[1,4,2] = 7
[4,2,5] = 11
[2,5,3] = 10
[1,4,2,5,3] = 15
我们将所有值求和得到:
1 + 4 + 2 + 5 + 3 + 7 + 11 + 10 + 15 = 58

思路

因为是要返回奇数长度子数组的和,由此可以使用range()的切片加步长方法,即range( , ,2),以此来实现奇数长度子数组的筛选

之后使用for循环进行数组值的累加,这里为了避免超过最大长度,需要设置一个范围,即len(arr)-n+1。然后使用sum进行累加即可。

提交结果:

完整代码

arr=[1,4,2,5,3]
sum1 = 0
for n in range(1, len(arr) + 1, 2):
    for i in range(len(arr) - n + 1):
        sum1 += sum(arr[i : i + n])
print(sum1)

posted @ 2021-03-09 18:51  乖张❤  阅读(127)  评论(0)    收藏  举报