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

题目接

题目:

分析:

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

代码:

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;
    }
}
相关推荐
郝学胜_神的一滴1 分钟前
力扣 144:二叉树前序遍历的优雅实现
数据结构·算法
zyl837213 分钟前
Python 四大核心数据结构:列表、字典、元组、集合
数据结构·windows·python
超梦dasgg6 分钟前
Dijkstra(迪杰斯特拉)算法详解
java·数据结构·算法
阿文的代码库8 分钟前
如何解决缺少特定算法思维的问题?
算法
yuan199979 分钟前
基于人工神经网络(ANN)的独立成分分析(ICA)算法
算法
代码地平线9 分钟前
C++ 入门篇类和对象·上篇:从本质深剖类与对象与C++基本用法
c语言·开发语言·数据结构·c++·笔记·算法
Hali_Botebie11 分钟前
期望最大化算法,Expectation-Maximization Algorithm
算法
weixin_4684668521 分钟前
通义千问核心能力与实战表现深度评测
人工智能·深度学习·算法·ai·大模型
菜菜的顾清寒24 分钟前
力扣HOT100(48)图论-腐烂的橘子
算法·leetcode·图论
Ulyanov32 分钟前
深入QML滑块与进度控制:构建动态数据可视化界面:QML+PySide6现代开发入门(六)
开发语言·python·算法·ui·信息可视化·雷达电子对抗仿真