[算法--前缀和] 寻找数组的中心下标

目录

    • [1. 前缀和思想是利用前面的计算减少后面不必要的计算.](#1. 前缀和思想是利用前面的计算减少后面不必要的计算.)

好的, 我们来分享一道关于前缀和算法的简单练习题 -> 寻找数组的中心下标

这道题很显然比较直接的方式是去用枚举法挨个试, 但是这个过程中会有大量重复计算, 会自然的想到前缀和算法.

1. 前缀和思想是利用前面的计算减少后面不必要的计算.

这个题目的思路非常简单和清晰, 感觉是属于十分简单的那一种题目了, 在思路和编码上都没有什么需要注意的地方. 下面简单说一下思路和给一个参考代码吧:

我们从中心下标的定义可以知道, 出中心下标的元素之外, 该元素的左边的 [前缀和 ] 等于该元素右边的 [后缀和 ]. 因此, 我们可以预先处理两个数组, 一个表示 [前缀和 ], 另一个表示 [后缀和 ].

然后, 我们可以用一个for循环枚举可能出现的中心下表, 判断每一个位置的前缀和以及后缀和, 如果二者相等, 就返回当前下标.

我们可以用下面图片来解释一下:

参考代码是:

cpp 复制代码
class Solution {
    public:
        int pivotIndex(vector<int>& nums) {
            int n = nums.size(); vector<int> v(n+1, 0);
            
            // 1. 制造前缀和数组
            for(int i = 0; i < n; i++) v[i+1] = v[i] + nums[i];
            
            // 2. 挨个测试
            for(int i = 0; i < n; i++)
                if(v[i] == v[n] - v[i+1]) return i;

            return -1;
        }
    };

⇒ 一键返回: 前缀和专题目录


EOF.

相关推荐
Hello__nibuhao4 分钟前
C 语言中控制文件的读取或写入光标
c语言·开发语言·算法
思茂信息10 分钟前
CST直角反射器 --- A求解器, 远场源, 距离像, 逆ChirpZ变换(ICZT)
开发语言·javascript·人工智能·算法·ai·软件工程·软件构建
AI 菌1 小时前
【DeepSeek系列】05 DeepSeek核心算法改进点总结
算法
Kent_J_Truman1 小时前
【删边问题——Tarjan求割边】
算法
武昌库里写JAVA2 小时前
《AI 大模型 ChatGPT 的传奇》
数据结构·vue.js·spring boot·算法·课程设计
GGBondlctrl2 小时前
【Leetcode】动态规划:从经典例题剖析解题精要
算法·leetcode·动态规划·第n个泰波那契数列·最小花费楼梯
数维学长9862 小时前
支持向量机 (Support Vector Machine, SVM)
算法·机器学习·支持向量机
没明白白3 小时前
选择排序:简单高效的选择
数据结构·算法·排序算法
近听水无声4773 小时前
算法基础篇--模拟
算法
程序员南飞3 小时前
算法-数据结构(图)-DFS深度优先遍历
java·数据结构·算法·职场和发展·深度优先