Java寻找数组的中心下标

简介: 1.题目描述2.题解分析具体实现

1.题目描述

给你一个整数数组 nums ,请计算数组的 中心下标


数组 中心下标 是数组的一个下标,其左侧所有元素相加的和等于右侧所有元素相加的和。


如果中心下标位于数组最左端,那么左侧数之和视为 0 ,因为在下标的左侧不存在元素。这一点对于中心下标位于数组最右端同样适用。


如果数组有多个中心下标,应该返回 最靠近左边 的那一个。如果数组不存在中心下标,返回 -1 。


示例


输入:nums = [1, 7, 3, 6, 5, 6]

输出:3


中心下标mid 为3


中心下标左侧之和为 sum1 = nums[0] + nums[1] + nums[2] = 1 + 7 + 3 = 11


中心下标右侧之和为 sum2 = nums[4] + nums[5] = 5 + 6 = 11


2.题解

分析

通过题目描述和给出的示例,我们可以发现中心下标左侧数之和sum1与右侧数之和sum2相等,且sum1 + sum2 + nums[mid] = 数组所有元素之和total,sum1*2 + nums[mid] = total


因此,我们从左开始遍历数组,当nums[i] + sum1(左侧数之和)*2 = total时,i即为数组的中心下标


具体实现

classSolution {
publicintpivotIndex(int[] nums) {
//计算数组所有元素之和inttotal=0;
for (inti=0; i<nums.length; i++) {
total+=nums[i];
        }
//左侧数之和intsum=0;
for (inti=0; i<nums.length; i++) {
//当左侧数之和的2倍 + nums[i]为数组所有元素之和时,i为中心下标if(2*sum+nums[i] ==total){
returni;
            }else{
//继续遍历数组sum+=nums[i];
            }
        }
//未找到中心下标,返回-1return-1;
    }


注:题目出自力扣,链接如下


https://leetcode.cn/problems/find-pivot-index/description/

目录
相关文章
|
27天前
|
Java
|
1天前
|
存储 Java 数据处理
Java 数组的高级用法
在 Java 中,数组不仅可以存储同类型的数据,还支持多种高级用法,如多维数组(常用于矩阵)、动态创建数组、克隆数组、使用 `java.util.Arrays` 进行排序和搜索、与集合相互转换、增强 for 循环遍历、匿名数组传递以及利用 `Arrays.equals()` 比较数组内容。这些技巧能提升代码的灵活性和可读性,适用于更复杂的数据处理场景。
|
2天前
|
存储 Java
java的Excel导出,数组与业务字典匹配并去掉最后一个逗号
java的Excel导出,数组与业务字典匹配并去掉最后一个逗号
17 2
|
23天前
|
Java
Java数组的应用场景
Java数组的应用场景
28 1
|
23天前
|
存储 机器学习/深度学习 Java
Java数组
Java数组
25 1
|
19天前
|
存储 开发者 C#
WPF与邮件发送:教你如何在Windows Presentation Foundation应用中无缝集成电子邮件功能——从界面设计到代码实现,全面解析邮件发送的每一个细节密武器!
【8月更文挑战第31天】本文探讨了如何在Windows Presentation Foundation(WPF)应用中集成电子邮件发送功能,详细介绍了从创建WPF项目到设计用户界面的全过程,并通过具体示例代码展示了如何使用`System.Net.Mail`命名空间中的`SmtpClient`和`MailMessage`类来实现邮件发送逻辑。文章还强调了安全性和错误处理的重要性,提供了实用的异常捕获代码片段,旨在帮助WPF开发者更好地掌握邮件发送技术,提升应用程序的功能性与用户体验。
22 0
|
27天前
|
存储 Java 开发者
揭秘!HashMap底层结构大起底:从数组到链表,再到红黑树,Java性能优化的秘密武器!
【8月更文挑战第24天】HashMap是Java集合框架中的核心组件,以其高效的键值对存储和快速访问能力广受开发者欢迎。在JDK 1.8及以后版本中,HashMap采用了数组+链表+红黑树的混合结构,实现了高性能的同时解决了哈希冲突问题。数组作为基石确保了快速定位;链表则用于处理哈希冲突;而当链表长度达到一定阈值时,通过转换为红黑树进一步提升性能。此外,HashMap还具备动态扩容机制,当负载因子超过预设值时自动扩大容量并重新哈希,确保整体性能。通过对HashMap底层结构的深入了解,我们可以更好地利用其优势解决实际开发中的问题。
47 0
|
27天前
|
存储 搜索推荐 算法
在 Java 中如何更改数组列表的顺序
【8月更文挑战第23天】
14 0
|
27天前
|
存储 安全 Java
在 Java 中如何存储数组列表
【8月更文挑战第23天】
22 0
|
27天前
|
Java API
如何在 Java 中将 Arraylist 变成数组?
【8月更文挑战第23天】
22 0