力扣第1991题 找到数组的中间位置 c++注释版
题目
简单
给你一个下标从 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
。
示例 1:
输入:nums = [2,3,-1,8,4] 输出:3 解释: 下标 3 之前的数字和为:2 + 3 + -1 = 4 下标 3 之后的数字和为:4 = 4
示例 2:
输入:nums = [1,-1,4] 输出:2 解释: 下标 2 之前的数字和为:1 + -1 = 0 下标 2 之后的数字和为:0
示例 3:
输入:nums = [2,5] 输出:-1 解释: 不存在符合要求的 middleIndex 。
示例 4:
输入:nums = [1] 输出:0 解释: 下标 0 之前的数字和为:0 下标 0 之后的数字和为:0
提示:
1 <= nums.length <= 100
-1000 <= nums[i] <= 1000
思路和解题方法
- 首先,定义两个变量
right
和left
,分别表示当前元素右边部分的和和左边部分的和,初始值都为0。- 使用一个循环遍历数组
nums
中的每个元素:
- 将当前元素的值加到
right
中,表示当前元素右边部分的和。- 循环遍历数组
nums
的同时,执行以下操作:
- 将当前元素的值从
right
中减去,表示将当前元素从右边部分的和中去除。- 如果此时
left
的值等于right
的值,说明找到了符合条件的中间位置,即当前下标i
,返回i
。- 否则,将当前元素的值加到
left
中,表示将当前元素添加到左边部分的和中。- 如果循环结束后仍未找到符合条件的中间位置,则返回-1。
复杂度
时间复杂度:
O(n)
其中n是数组
nums
的长度。这是因为代码中使用了两个循环,第一个循环用于计算数组元素之和,需要遍历整个数组,所以时间复杂度为O(n)。第二个循环同样需要遍历整个数组,所以也需要O(n)的时间复杂度。
空间复杂度
O(1)
即常数级别的额外空间。无论输入的数组规模如何增大,代码所使用的额外空间都保持不变,只使用了固定数量的变量,因此空间复杂度为O(1)。
c++ 代码
class Solution {
public:
int findMiddleIndex(vector<int>& nums) {
int right = 0; // 右边部分的和
int left = 0; // 左边部分的和
for (int a : nums) { // 第一个循环,计算整个数组元素之和
right += a; // 将当前元素的值加到右边部分的和中
}
for (int i = 0; i < nums.size(); i++) { // 第二个循环,遍历数组
right -= nums[i]; // 将当前元素的值从右边部分的和中减去
if (left == right) { // 如果左边部分的和等于右边部分的和
return i; // 返回当前下标i作为中间位置
}
left += nums[i]; // 将当前元素的值加到左边部分的和中
}
return -1; // 循环结束后仍未找到符合条件的中间位置,返回-1
}
};
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)