gpt4 book ai didi

leetcode刷题(第1588题)——所有奇数长度子数组的和

转载 作者:知者 更新时间:2024-03-13 02:39:17 28 4
gpt4 key购买 nike

一、题目

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

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

请你返回 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

三、思路
本题需要两层遍历,不断累加即可。
四、代码

/**
 * @param {number[]} arr
 * @return {number}
 */
var sumOddLengthSubarrays = function(arr) {
    let len = arr.length
    let res = 0
    for(let step = 1; step <= len; step+=2 ) {
        for(let i = 0; i < len; i++) {
            if(i + step <= len) {
                let curArr = arr.slice(i, i + step)
                curArr.forEach(item => res += item)
            }else {
                break
            }
        }
    }
    return res
};

五、总结

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com