• 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;
            }
        }
    
  • 相关阅读:
    查找算法(I) 顺序查找 二分查找 索引查找
    快速排序 Quick Sort
    Activity生命周期
    Android中资源文件的使用
    排序算法
    插入排序(I)Insert Sort
    Java eclipse调试技巧什么的。。
    HTTP协议解析
    python技巧26[str+unicode+codecs]
    python类库26[PySide之helloworld]
  • 原文地址:https://www.cnblogs.com/smakslow/p/15228727.html
Copyright © 2020-2023  润新知