[优选算法专题四.前缀和——NO.27 寻找数组的中心下标]

题目链接:

寻找数组的中心下标

题目描述:

题目解析:


核心思路

通过预处理两个辅助数组:

  • 前缀和数组 ff[i] 表示下标 i 左侧所有元素的总和(不包含 nums[i] 本身)。
  • 后缀和数组 gg[i] 表示下标 i 右侧所有元素的总和(不包含 nums[i] 本身)。

然后遍历数组,判断每个下标 if[i] 是否等于 g[i],若相等则 i 即为中心下标。

总结

  • 时间复杂度O(n),其中 n 是数组长度。预处理两个数组和遍历数组均为线性时间。
  • 空间复杂度O(n),用于存储前缀和数组 f 和后缀和数组 g(可优化至 O(1),通过先计算总 sum,再用单变量实时计算左侧和,右侧和 = 总 sum - 左侧和 - 当前元素)。
  • 关键点:前缀和与后缀和的定义清晰区分了「不包含当前元素」,避免了重复计算。
相关推荐
hh随便起个名6 小时前
力扣二叉树的三种遍历
javascript·数据结构·算法·leetcode
Dingdangcat867 小时前
城市交通多目标检测系统:YOLO11-MAN-FasterCGLU算法优化与实战应用_3
算法·目标检测·目标跟踪
xie_pin_an8 小时前
深入浅出 C 语言数据结构:从线性表到二叉树的实战指南
c语言·数据结构·图论
tang&8 小时前
滑动窗口:双指针的优雅舞步,征服连续区间问题的利器
数据结构·算法·哈希算法·滑动窗口
拼命鼠鼠8 小时前
【算法】矩阵链乘法的动态规划算法
算法·矩阵·动态规划
LYFlied8 小时前
【每日算法】LeetCode 17. 电话号码的字母组合
前端·算法·leetcode·面试·职场和发展
式5168 小时前
线性代数(八)非齐次方程组的解的结构
线性代数·算法·机器学习
Nandeska9 小时前
2、数据库的索引与底层数据结构
数据结构·数据库
橘颂TA9 小时前
【剑斩OFFER】算法的暴力美学——翻转对
算法·排序算法·结构与算法
叠叠乐9 小时前
robot_state_publisher 参数
java·前端·算法