当前位置: 首页 > news >正文

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 代码实现

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;  
}
http://www.lryc.cn/news/208928.html

相关文章:

  • 物联网数据采集网关连接设备与云平台的关键桥梁
  • 专家级数据恢复:UFS Explorer Professional Recovery Crack
  • 2023/10/23 mysql学习
  • 软考系统架构师知识点集锦六:项目管理
  • MacOS系统Chrome开发者模式下载在线视频
  • uniapp v3+ts 使用 u-upload上传图片以及视频
  • 为什么虚拟dom会提高性能?
  • 2015年亚太杯APMCM数学建模大赛A题海上丝绸之路发展战略的影响求解全过程文档及程序
  • js中HTMLCollection如何循环
  • Kafka - 3.x 副本不完全指北
  • 二分归并法将两个数组合并
  • ROS自学笔记十六:URDF优化_xacro文件
  • XMLHttpRequest拦截请求和响应
  • 前端 读取/导入 Excel文档
  • 聊聊springboot的TomcatMetricsBinder
  • 《动手学深度学习 Pytorch版》 10.6 自注意力和位置编码
  • 2023年第四届MathorCup高校数学建模挑战赛——大数据竞赛B题 实现代码
  • larvel 中的api.php_Laravel 开发 API
  • 虚拟机构建部署单体项目及前后端分离项目
  • C++之特殊类的设计
  • Java练习题2020 -1
  • LuaTable转C#的列表List和字典Dictionary
  • Redis快速上手篇七(集群)
  • Mac 安装nvm
  • python 从mssql取出datetime2类型之后格式化
  • 18.2 使用NPCAP库抓取数据包
  • pytest-yaml 测试平台-3.创建执行任务定时执行用例
  • 安卓文件资源中,一个字串包含引用其他字串的写法
  • 解决:谷歌浏览器访问http时,自动转https访问的问题
  • MQTT协议和边缘计算