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

目录

    • [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.

相关推荐
圈圈编码28 分钟前
LeetCode Hot100刷题——合并两个有序链表
java·数据结构·算法·leetcode·链表
老歌老听老掉牙1 小时前
旋量理论:刚体运动的几何描述与机器人应用
python·算法·机器学习·机器人·旋量
无聊的小坏坏1 小时前
用递归算法解锁「子集」问题 —— LeetCode 78题解析
算法·深度优先
m0_738596322 小时前
十大排序算法
算法·排序算法
jingfeng5142 小时前
详解快排的四种方式
数据结构·算法·排序算法
MoRanzhi12032 小时前
245. 2019年蓝桥杯国赛 - 数正方形(困难)- 递推
python·算法·蓝桥杯·国赛·递推·2019
henyaoyuancc2 小时前
vla学习 富
人工智能·算法
Gyoku Mint3 小时前
机器学习×第五卷:线性回归入门——她不再模仿,而开始试着理解你
人工智能·python·算法·机器学习·pycharm·回归·线性回归
蒙奇D索大4 小时前
【数据结构】图论最短路径算法深度解析:从BFS基础到全算法综述
数据结构·算法·图论·广度优先·图搜索算法
trouvaille4 小时前
哈希数据结构的增强
算法·go