leetcode724 寻找数组的中心下标

题目

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

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

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

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

复制代码
输入:nums = [1, 7, 3, 6, 5, 6]
输出:3
解释:
中心下标是 3 。
左侧数之和 sum = nums[0] + nums[1] + nums[2] = 1 + 7 + 3 = 11 ,
右侧数之和 sum = nums[4] + nums[5] = 5 + 6 = 11 ,二者相等。

解法

前缀和的经典题目,前缀和的思路是由于解题过程中要频繁用到数组的和,那么我们不妨一开始就直接构建出数组保存数组的前缀和。

具体思路如下:

至于为什么要从s[0]开始构造,敲黑板,是因为前缀和一般利用起来都是大的前缀和减去小的前缀和的形式,如果不构造s[0],则无法以同一种形式处理所有带a[0]的部分,两个前缀和相减,都会直接消去它。

另外需要注意的是前i-1项和的索引是s[i]。

我的解法如下:(找到我学不了算法的原因了,我学到了前缀和的形式,别人学到了前缀和的灵魂)

复制代码
class Solution:
    def pivotIndex(self, nums: List[int]) -> int:
        s = [0]*(len(nums)+1)
        for i, x in enumerate(nums):
            s[i+1] = s[i] + x

        for i in range(1,len(nums)+1):
            if i==1:
                if s[len(nums)]-s[1]==0:
                    return i-1
            elif i==len(nums):
                if s[len(nums)]-nums[len(nums)-1]==0:
                    return i-1
            else:
                if s[i-1]==s[len(nums)]-s[i]:
                    return i-1
        return -1

灵神解法

他其实每次都在使用的是总和,然后灵神巧妙地借助了leftS,完成了这个巧夺天工的解题思路。

相关推荐
gfdhy5 小时前
【c++】哈希算法深度解析:实现、核心作用与工业级应用
c语言·开发语言·c++·算法·密码学·哈希算法·哈希
百***06015 小时前
SpringMVC 请求参数接收
前端·javascript·算法
weixin_457760005 小时前
Python 数据结构
数据结构·windows·python
一个不知名程序员www6 小时前
算法学习入门---vector(C++)
c++·算法
云飞云共享云桌面6 小时前
无需配置传统电脑——智能装备工厂10个SolidWorks共享一台工作站
运维·服务器·前端·网络·算法·电脑
明洞日记7 小时前
【数据结构手册002】动态数组vector - 连续内存的艺术与科学
开发语言·数据结构·c++
福尔摩斯张7 小时前
《C 语言指针从入门到精通:全面笔记 + 实战习题深度解析》(超详细)
linux·运维·服务器·c语言·开发语言·c++·算法
fashion 道格7 小时前
数据结构实战:深入理解队列的链式结构与实现
c语言·数据结构
橘颂TA7 小时前
【剑斩OFFER】算法的暴力美学——两整数之和
算法·leetcode·职场和发展
xxxxxxllllllshi8 小时前
【LeetCode Hot100----14-贪心算法(01-05),包含多种方法,详细思路与代码,让你一篇文章看懂所有!】
java·数据结构·算法·leetcode·贪心算法