个人网站引导页源码,如何用手机做网页,网页版qq邮箱怎么发文件,国外排版网站1 题目描述
给你一个下标从 0 开始的整数数组 nums , 请你找到 最左边 的中间位置 middleIndex #xff08;也就是所有可能中间位置下标最小的一个#xff09;
中间位置 middleIndex 是满足 nums[0] nums[1] ... nums[middleIndex-1] nums[middleIndex1] nums[middleI…1 题目描述
给你一个下标从 0 开始的整数数组 nums , 请你找到 最左边 的中间位置 middleIndex 也就是所有可能中间位置下标最小的一个
中间位置 middleIndex 是满足 nums[0] nums[1] ... nums[middleIndex-1] nums[middleIndex1] nums[middleIndex2] ... 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 之后的数字和为02 解题思路
解题思路:
计算数组总和遍历数组, 计算左边的和, 右边的和 数组总和 - 左边的和 - 当前元素如果左边的和 * 2 当前元素 数组总和, 则找到了中间下标, 返回当前下标
2.1 代码实现
public int findMiddleIndex(int[] nums) { // 计算数组总和 int total Arrays.stream(nums).sum(); int sum 0; // 遍历数组, 计算左边的和, 右边的和 数组总和 - 左边的和 - 当前元素 for (int i 0; i nums.length; i) { // 如果左边的和 * 2 当前元素 数组总和, 则找到了中间下标, 返回当前下标 if (2 * sum nums[i] total) { return i; } // 将当前元素加入到左边的和中 sum nums[i]; } return -1;
}