前缀和——中心数组下标

此题我们不应局限于前缀和的模板,因为该中心下标把数组分为两个部分且每个部分都要求和,我们就一个再创建一个"后缀和"

定义两个数组f,g。f[i]表示[0,i-1]所有元素的和 f[i]=f[i-1]+nums[i-1];g[i]表示[i+1,n-1]的和

g[i]=g[i+1]+nums[i+1];因为依靠关系,f要从左到右,g要从右到左。

注意题干中的边界条件,0和n-1位置出的左、右是0,因此不要越界。

cpp 复制代码
int Solution(vector<int> nums)
{
    
   int n=nums.size();
 vector<int> f(n),g(n);
   //0,n-1的位置已经初始化为0
  for(int i=1;i<n;i++)
        f[i]=f[i-1]+nums[i-1];
   for(int i=n-2;i>=0;i--)
        g[i]=g[i+1]+nums[i+1];
    
  for(int i=0;i<n;i++)
   if(f[i]==g[i])
        return i;

  return -1;

}
相关推荐
C++ 老炮儿的技术栈3 分钟前
什么是通信规约
开发语言·数据结构·c++·windows·算法·安全·链表
零小陈上(shouhou6668889)15 分钟前
K-近邻算法 - lazy learning的代表
算法·近邻算法
有一个好名字21 分钟前
力扣-从字符串中移除星号
java·算法·leetcode
萧瑟其中~25 分钟前
二分算法模版——基础二分查找,左边界查找与右边界查找(Leetcode的二分查找、在排序数组中查找元素的第一个位置和最后一个位置)
数据结构·算法·leetcode
码上就好ovo27 分钟前
Atcoder Beginnner Contest 440
算法
高洁0134 分钟前
CLIP 的双编码器架构是如何优化图文关联的?(3)
深度学习·算法·机器学习·transformer·知识图谱
jllllyuz40 分钟前
MATLAB实现蜻蜓优化算法
开发语言·算法·matlab
iAkuya42 分钟前
(leetcode)力扣100 36二叉树的中序遍历(迭代递归)
算法·leetcode·职场和发展
wangwangmoon_light1 小时前
1.1 LeetCode总结(线性表)_枚举技巧
算法·leetcode·哈希算法