寻找数组的中心下标 ---- 前缀和

题目接

题目:

分析:

  • 这道题是求某个区间内数组的和, 所以可以用前缀和算法
  • 假设i位置是中心位置, 我们要知道[0,i - 1]的和 和 [i + 1,n - 1]的和 看是否相等
  • 先求[0,i - 1]的和 用一个前缀数组f
    此时f[i] 表示: 前i - 1个数的和, 那么f[i - 1] 就表示前i - 2的和, 所以让f[0] = 0, i从1开始, 从前往后遍历
    f[i] = f[i - 1] + nums[i - 1]
  • 求[i + 1,n - 1]的和 用一个后缀数组g
    此时g[i] 表示: 后i + 1个数的和, 那么g[i + 1] 就表示后i + 2的和, 所以让g[n - 1] = 0, i从n-2开始, 从后往前遍历
    g[i] = g[i + 1] + nums[i + 1]
  • 从头遍历数组, 判断f[i] 是否等于 g[i]

代码:

java 复制代码
class Solution {
    public int pivotIndex(int[] nums) {
        int n = nums.length;
        int[] f = new int[n];
        int[] g = new int[n];
        for (int j = 1; j < n; j++) {
            f[j] = f[j - 1] + nums[j -1];
        }
        for (int j = n - 2; j >= 0; j--) {
            g[j] = g[j + 1] + nums[j + 1];
        }
        for (int i = 0; i < n; i++) {
            if(f[i] == g[i]){
                return i;
            }
        }
        return -1;
    }
}
相关推荐
勇闯逆流河34 分钟前
【数据结构】堆
c语言·数据结构·算法
pystraf1 小时前
LG P9844 [ICPC 2021 Nanjing R] Paimon Segment Tree Solution
数据结构·c++·算法·线段树·洛谷
飞川撸码2 小时前
【LeetCode 热题100】739:每日温度(详细解析)(Go语言版)
算法·leetcode·golang
yuhao__z2 小时前
代码随想录算法训练营第六十六天| 图论11—卡码网97. 小明逛公园,127. 骑士的攻击
算法
Echo``2 小时前
3:OpenCV—视频播放
图像处理·人工智能·opencv·算法·机器学习·视觉检测·音视频
Nobkins3 小时前
2021ICPC四川省赛个人补题ABDHKLM
开发语言·数据结构·c++·算法·图论
88号技师3 小时前
2025年6月一区SCI-不实野燕麦优化算法Animated Oat Optimization-附Matlab免费代码
开发语言·算法·matlab·优化算法
ysy16480672394 小时前
03算法学习_977、有序数组的平方
学习·算法
codists4 小时前
《算法导论(第4版)》阅读笔记:p83-p85
算法
Tiny番茄5 小时前
归一化函数 & 激活函数
人工智能·算法·机器学习