leetcode如何寻找数组的中心索引
发表于:2025-02-03 作者:千家信息网编辑
千家信息网最后更新 2025年02月03日,小编给大家分享一下leetcode如何寻找数组的中心索引,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!一、题目内容给定一个
千家信息网最后更新 2025年02月03日leetcode如何寻找数组的中心索引
小编给大家分享一下leetcode如何寻找数组的中心索引,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
一、题目内容
给定一个整数类型的数组 nums,请编写一个能够返回数组 "中心索引" 的方法。
我们是这样定义数组 中心索引 的:数组中心索引的左侧所有元素相加的和等于右侧所有元素相加的和。
如果数组不存在中心索引,那么我们应该返回 -1。如果数组有多个中心索引,那么我们应该返回最靠近左边的那一个。
示例 1:
输入:
nums = [1, 7, 3, 6, 5, 6]
输出:3
解释:
索引 3 (nums[3] = 6) 的左侧数之和 (1 + 7 + 3 = 11),与右侧数之和 (5 + 6 = 11) 相等。
同时, 3 也是第一个符合要求的中心索引。
示例 2:
输入:
nums = [1, 2, 3]
输出:-1
解释:
数组中不存在满足此条件的中心索引。
说明:
nums 的长度范围为 [0, 10000]。
任何一个 nums[i] 将会是一个范围在 [-1000, 1000]的整数。
二、解题思路
先计算nums所有元素的和,然后从左到右计算左边的和,如果:
左边和 * 2+当前元素 = 所有元素和
则返回当前元素索引,否则返回-1。
三、代码
class Solution: def pivotIndex(self, nums: list) -> int: whole_sum = sum(nums) left_sum = 0 for i in range(len(nums)): if left_sum * 2 + nums[i] == whole_sum: return i else: left_sum += nums[i] return -1if __name__ == '__main__': s = Solution() nums1 = [1, 7, 3, 6, 5, 6] ans1 = s.pivotIndex(nums1) print(ans1) nums2 = [1, 2, 3] ans2 = s.pivotIndex(nums2) print(ans2) nums3 = [-1, -1, -1, -1, -1, -1] ans3 = s.pivotIndex(nums3) print(ans3) nums4 = [-1, -1, -1, -1, -1, 0] ans4 = s.pivotIndex(nums4) print(ans4)
以上是"leetcode如何寻找数组的中心索引"这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注行业资讯频道!
索引
数组
元素
内容
篇文章
之和
右侧
整数
示例
范围
解释
输入
输出
不怎么
代码
同时
多个
大部分
思路
方法
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
保证数据库独立性的关键因素是
DFD应该与数据库技术中的
第1章vc软件开发基础
陶瓷文物的数据库
量子大学网络安全
逃离塔科夫建服务器
怎么单独注销王者多余的服务器
只只大冒险无法连接服务器
车生活互联网科技
护卫神 数据库端口
网络技术中网络设备安装与调试
带宽延迟要求网络技术
学计算机网络技术的在板厂能做啥
服务器 1u
我的世界服务器自定义npc音乐
数据库开发的方法有几种
spring数据库连接池
网络文明网络安全范文
山东酒店hr软件开发
网站数据库自动备份
我的世界服务器ice解说
数据库大批量插入性能优化
直播聊天机器人软件开发
网络技术员工资高吗
成绩分析系统数据库设计
数据库原理考研大学排名
关于网络安全的个股
深圳ips网络安全厂商
网络技术与电子商务区别
苏州软件开发月薪