寻找数组的中心索引

给定一个整数类型的数组 nums,请编写一个能够返回数组“中心索引”的方法。

我们是这样定义数组中心索引的:数组中心索引的左侧所有元素相加的和等于右侧所有元素相加的和。

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

示例 1:

  1. 输入:
  2. nums = [1, 7, 3, 6, 5, 6]
  3. 输出: 3
  4. 解释:
  5. 索引3 (nums[3] = 6) 的左侧数之和(1 + 7 + 3 = 11),与右侧数之和(5 + 6 = 11)相等。
  6. 同时, 3 也是第一个符合要求的中心索引。

示例 2:

  1. 输入:
  2. nums = [1, 2, 3]
  3. 输出: -1
  4. 解释:
  5. 数组中不存在满足此条件的中心索引。

说明:

  • nums 的长度范围为 [0, 10000]
  • 任何一个 nums[i] 将会是一个范围在 [-1000, 1000]的整数。

起先我的思路是从第一个索引左累加、右累加判断是否想等:

  1. import java.util.ArrayList;
  2. import java.util.List;
  3. import java.util.Scanner;
  4. public class Main {
  5. public static void main(String[] args) {
  6. List<Integer> nums = new ArrayList<>();
  7. int sumLeft=0,sumRight=0;
  8. Scanner scan =new Scanner(System.in);
  9. while (scan.hasNextInt()){
  10. nums.add(scan.nextInt());
  11. }
  12. int numsSize=nums.size()-1;
  13. for(int i=1;i<numsSize;i++){
  14. for(int j=0;j<i;j++){
  15. sumLeft+=nums.get(j);
  16. }
  17. for(int j=numsSize;j>i;j--){
  18. sumRight+=nums.get(j);
  19. }
  20. if(sumLeft==sumRight){
  21. System.out.println(i);
  22. break;
  23. }else {
  24. sumLeft=sumRight=0;
  25. }
  26. }
  27. if(sumLeft==0){
  28. System.out.println(-1);
  29. }
  30. }
  31. }

做完之后搜一下别人的答案。。。果然被吊打。

解题思路:

参考博客园

左累加没必要从0号索引开始,之前的累加加上下一号索引即可。右累加完全可以算一次总和减去左累加即可。

参考:判断中心索引条件

左侧索引如果和右侧相等,即二倍加左侧累加和+中心索引=总和

java:

  1. class Solution {
  2. public int pivotIndex(int[] nums) {
  3. int sumLeft=0,sum=0;
  4. for (int n:nums){
  5. sum = sum + n;
  6. }
  7. int numsSize=nums.length-1;
  8. for(int i=0;i<=numsSize;i++){
  9. if(i==0){
  10. sumLeft=0;
  11. }else{
  12. sumLeft+=nums[i-1];
  13. }
  14. //左侧索引如果和右侧相等,即二倍左侧加中心索引=总和
  15. if(sumLeft*2+nums[i]==sum){
  16. return i;
  17. }
  18. }
  19. return -1;
  20. }
  21. }

特别说明一下,索引一定要从0开始到最后一个止,因为题目后中心索引右侧相加可以为0。

java默认模板里int[] nums指从控制台输入int 数组,不需要Arraylist动态构造数组了。

python3

​ nums即为list动态数组

  1. class Solution:
  2. def pivotIndex(self, nums: List[int]) -> int:
  3. """
  4. :type nums: int
  5. """
  6. sumAll=sum(nums)
  7. leftSum=0
  8. for i in range(len(nums)):
  9. if(i==0):
  10. leftSum=0
  11. else:
  12. leftSum+=nums[i-1]
  13. #左侧索引如果和右侧相等,即二倍加左侧中心索引=总和
  14. if(leftSum*2+nums[i]==sumAll):
  15. return i
  16. return -1

Leetcode724:寻找数组的中心索引(java、python3)的更多相关文章

  1. LeetCode724. 寻找数组的中心索引

    1.题目描述 给定一个整数类型的数组 nums,请编写一个能够返回数组“中心索引”的方法. 我们是这样定义数组中心索引的:数组中心索引的左侧所有元素相加的和等于右侧所有元素相加的和. 如果数组不存在中 ...

  2. [Swift]LeetCode724. 寻找数组的中心索引 | Find Pivot Index

    Given an array of integers nums, write a method that returns the "pivot" index of this arr ...

  3. Java实现 LeetCode 724 寻找数组的中心索引(暴力)

    724. 寻找数组的中心索引 给定一个整数类型的数组 nums,请编写一个能够返回数组"中心索引"的方法. 我们是这样定义数组中心索引的:数组中心索引的左侧所有元素相加的和等于右侧 ...

  4. LeetCode:寻找数组的中心索引【668】

    LeetCode:寻找数组的中心索引[668] 题目描述 给定一个整数类型的数组 nums,请编写一个能够返回数组“中心索引”的方法. 我们是这样定义数组中心索引的:数组中心索引的左侧所有元素相加的和 ...

  5. Leetcode724.Find Pivot Index寻找数组的中心索引

    给定一个整数类型的数组 nums,请编写一个能够返回数组"中心索引"的方法. 我们是这样定义数组中心索引的:数组中心索引的左侧所有元素相加的和等于右侧所有元素相加的和. 如果数组不 ...

  6. 力扣(LeetCode)寻找数组的中心索引 个人题解

    给定一个整数类型的数组 nums,请编写一个能够返回数组“中心索引”的方法. 我们是这样定义数组中心索引的:数组中心索引的左侧所有元素相加的和等于右侧所有元素相加的和. 如果数组不存在中心索引,那么我 ...

  7. 【LeetCode】724. 寻找数组的中心下标

    724. 寻找数组的中心下标 知识点:数组:前缀和: 题目描述 给你一个整数数组 nums ,请计算数组的 中心下标 . 数组 中心下标 是数组的一个下标,其左侧所有元素相加的和等于右侧所有元素相加的 ...

  8. C#LeetCode刷题之#724-寻找数组的中心索引( Find Pivot Index)

    问题 该文章的最新版本已迁移至个人博客[比特飞],单击链接 https://www.byteflying.com/archives/3742 访问. 给定一个整数类型的数组 nums,请编写一个能够返 ...

  9. Java算法分析1—————寻找数组同样元素

    算法的两个评測指标:执行时间和内存消耗 要么用时间换空间,要么用空间换时间 寻找数组同样元素測试一: 0~99共100个元素各不同样,新增加一个0~99的元素不明白位置 从101个元素数组中找出与0~ ...

随机推荐

  1. Mac SavePanel 保存文件的GUI代码

    // Move the recorded temporary file to a user-specified location (视频文件另存储过程,依据用户选择的路径和文件保存名) NSSaveP ...

  2. 获取SQLServer连接字符串的方法

     第一步:创建向导文件 在桌面创建一个txt文件,并将文件后缀改成“.udl”.    第二步:选择“提供程序”tab页 双击新创建的“.udl”文件,进入后选择“提供程序”tab页,选择“Micro ...

  3. javax.servlet.http.Part 文件上传

    编辑jsp页面: <html> <head> <base href="<%=basePath%>"> <title>My ...

  4. Centos7 防火墙firewalld配置

    开启80端口 firewall-cmd --zone=public --add-port=80/tcp --permanent  出现success表明添加成功 移除某个端口 firewall-cmd ...

  5. Web 设计与开发者必须知道的 15 个站点

    新闻来源:catswhocode.com公司博客整整一个月没有更新了,最近一段时间,全公司都忙于两件事,为海尔集团做定制,为一个合作伙伴做 OEM,终于有了眉目.工作期间,常用到一些工具与帮助站点,今 ...

  6. HDU 1394 线段树or 树状数组~

    Minimum Inversion Number Description The inversion number of a given number sequence a1, a2, ..., an ...

  7. CSYZDay1模拟题解

    T1.game [问题描述] LZK发明一个矩阵游戏,大家一起来玩玩吧,有一个N行M列的矩阵.第一行的数字是1,2,…M,第二行的数字是M+1,M+2…2*M,以此类推,第N行的数字是(N-1)*M+ ...

  8. IDEA hadoop MapReduce 环境配置

    1.下载,安装,配置好Hadoop 2.在IDEA中执行MapReduc 配置: 这里将JAR包加入: JAR包是:/usr/local2/hadoop/share/hadoop 目录下:直接右边+以 ...

  9. bzoj 1664: [Usaco2006 Open]County Fair Events 参加节日庆祝【dp+树状数组】

    把长度转成右端点,按右端点排升序,f[i]=max(f[j]&&r[j]<l[i]),因为r是有序的,所以可以直接二分出能转移的区间(1,w),然后用树状数组维护区间f的max, ...

  10. bzoj 1650: [Usaco2006 Dec]River Hopscotch 跳石子【贪心+二分】

    脑子一抽写了个堆,发现不对才想起来最值用二分 然后判断的时候贪心的把不合mid的区间打通,看打通次数是否小于等于m即可 #include<iostream> #include<cst ...