LeetCode--1991.找到数组的中间位置

1 题目描述

给你一个下标从 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

2 解题思路

解题思路:

  1. 计算数组总和
  2. 遍历数组, 计算左边的和, 右边的和 = 数组总和 - 左边的和 - 当前元素
  3. 如果左边的和 * 2 + 当前元素 = 数组总和, 则找到了中间下标, 返回当前下标

2.1 代码实现

java 复制代码
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;  
}
相关推荐
IronMurphy6 小时前
【算法二十六】108. 将有序数组转换为二叉搜索树 98. 验证二叉搜索树
数据结构·算法·leetcode
im_AMBER6 小时前
Leetcode 141 最长公共前缀 | 罗马数字转整数
算法·leetcode
WolfGang0073217 小时前
代码随想录算法训练营 Day13 | 二叉树 part03
数据结构·算法·leetcode
一叶落4388 小时前
167. 两数之和 II - 输入有序数组【C语言题解】
c语言·数据结构·算法·leetcode
一叶落4389 小时前
LeetCode 54. 螺旋矩阵(C语言详解)——模拟 + 四边界收缩
java·c语言·数据结构·算法·leetcode·矩阵
Storynone9 小时前
【Day27】LeetCode:56. 合并区间,738. 单调递增的数字
python·算法·leetcode
计算机安禾10 小时前
【C语言程序设计】第31篇:指针与函数
c语言·开发语言·数据结构·c++·算法·leetcode·visual studio
Frostnova丶10 小时前
LeetCode 3070. 元素和小于等于 k 的子矩阵数目
算法·leetcode·矩阵
不想看见40411 小时前
Implement Queue using Stacks栈和队列--力扣101算法题解笔记
笔记·算法·leetcode
MrZhangBaby11 小时前
SQL-leetcode—3482. 分析组织层级
数据库·sql·leetcode