zoukankan      html  css  js  c++  java
  • 5846. 找到数组的中间位置

    5846. 找到数组的中间位置

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

    来源:力扣(LeetCode)
    链接:https://leetcode-cn.com/problems/find-the-middle-index-in-array/
    著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

      class Solution {
            public int findMiddleIndex(int[] nums) {
                int left = 0, right = 0;
                right = Arrays.stream(nums).sum();
                for (int i = 0; i < nums.length; i++) {
                    right -= nums[i];
                    if (left == right) return i;
                    left += nums[i];
                }
                return -1;
            }
        }
    
  • 相关阅读:
    Luogu P4727 [HNOI2009]图的同构记数
    ARC 101 E
    JSOI2019 Round2 游记
    JSOI2019 Round1(十二省联考)游记
    Technocup 2019
    Codeforces Round #533 (Div. 2)比赛总结
    学习链接
    2018.12.29-2018.1.9安师大附中集训
    关于考试
    NOIP2018提高组 游记
  • 原文地址:https://www.cnblogs.com/smakslow/p/15228727.html
Copyright © 2011-2022 走看看