给你一个下标从 0 开始的整数数组 nums ,请你找到 最左边 的中间位置 middleIndex (也就是所有可能中间位置下标最小的一个)。
中间位置 middleIndex 是满足 nums[0] + nums[1] + ... + nums[middleIndex-1] == nums[middleIndex+1] + nums[middleIndex+2] + ... + nums[nums.length-1] 的数组下标。
如果 middleIndex == 0 ,左边部分的和定义为 0 。类似的,如果 middleIndex == nums.length - 1 ,右边部分的和定义为 0 。
请你返回满足上述条件 最左边 的 middleIndex ,如果不存在这样的中间位置,请你返回 -1 。
来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/find-the-middle-index-in-array
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。题目传送门:力扣
class Solution {
public:
int findMiddleIndex(vector<int>& nums) {
int pos = -1;
int posVal = 0;
int leftSum = 0;
int rightSum = 0;
auto begin = nums.begin();
auto end = nums.end();
while (begin != end)
rightSum += *begin++;
for (int i = 0; i < nums.size(); i++)
{
leftSum += posVal;
posVal = nums[i];
rightSum -= posVal;
if (leftSum == rightSum)
{
pos = i;
break;
}
}
return pos;
}
};