【Leetcode】1588.所有奇数长度子数组的和

题目描述


思路

题目要求我们求解所有奇数长度数组的和。若暴力循环求解,时间复杂度过高。所以,我们可以采用前缀和优化。

如上图输入arr数组,sum[i]用于计算arr数组中前i个数的和。(在程序中,先给sum[0]赋值,等于arr[0],其余sum[i]=sum[i-1]+arr[i])

接着,我们计算需要返回的ret。我们定义两个循环变量i和j。先定i不动,j向后移动,然后每移动一个位置,就判断一下,是否i和j之间相差奇数个数,若是,则ret+=sum[j]-sum[i-1]。(包括i,所以是减去前一个位置的。)

然后i作为外层循环,后续循环如上面一样判断。

代码

cpp 复制代码
class Solution {
public:
        int sumOddLengthSubarrays(vector<int>&arr) {
        
        int length=arr.size();//获取数组中元素的个数
        int sum[length];//定义前缀和数组
        long long int ret;
        ret=0;
        sum[0]=arr[0];
        //计算前缀和
        for (int i=1;i<length;i++)
        {
            sum[i]=sum[i-1]+arr[i];
        }
        
        for (int  i=0;i<length;i++)
        {
            for (int j=i;j<length;j++)
            {
                
            if ((j-i+1)%2)//若相差奇数个数
            {
            if (i==0) ret+=sum[j];//i=0时,不分开讨论sum[i-1]数组越界。
            else
                ret+=sum[j]-sum[i-1];
            }
            
            }
        }
        return ret;
        }
};
相关推荐
天真小巫几秒前
2026.5.7总结
职场和发展
TANGLONG2223 分钟前
【C++】STL基础必备:深入解析vector容器的实现(含源码)
c语言·开发语言·数据结构·c++·笔记·算法·stl
50万马克的面包8 分钟前
C语言第3讲:分支和循环
c语言·开发语言·笔记·算法
码农小韩13 分钟前
QT学习记录(三)——C++学习基础(三)
开发语言·c++·qt·学习·算法·嵌入式软件
承渊政道16 分钟前
【动态规划算法】(似包非包以及卡特兰数问题深入解析)
数据结构·c++·学习·算法·leetcode·动态规划·哈希算法
fangzt201025 分钟前
从零搭建自动驾驶中间件(四):数据录制与回灌——算法调试的核心基础设施
算法·中间件·自动驾驶
人道领域28 分钟前
【LeetCode刷题日记】二叉树层序遍历完全指南:从基础到LeetCode实战一篇搞定BFS模板,秒杀4道经典面试题
java·开发语言·数据结构·leetcode·面试·二叉树
QD_ANJING31 分钟前
建议5月的Web前端开发都去飞书上准备面试...
前端·人工智能·面试·职场和发展·前端框架·状态模式·ai编程
搬砖的小码农_Sky33 分钟前
比特币区块链:SHA256哈希函数
算法·区块链·哈希算法
承渊政道42 分钟前
【动态规划算法】(一文讲透二维费用的背包问题)
数据结构·c++·学习·算法·leetcode·动态规划·哈希算法