当前位置:首页 > 文章列表 > 文章 > python教程 > Python前缀和数组快速查询技巧

Python前缀和数组快速查询技巧

2026-05-15 16:50:38 0浏览 收藏
本文深入解析了Python中前缀和数组的核心实现技巧与常见陷阱,系统讲解了一维前缀和如何通过长度为n+1的数组高效支持O(1)区间求和查询(关键在于prefix[r+1]−prefix[l]的下标设计),以及二维前缀和如何借助容斥原理计算子矩阵和(必须多开行列、严格遵循加减顺序),同时强调避免浅拷贝、实时切片、numpy.cumsum误用等高频错误,并明确指出前缀和仅适用于静态数据+高频查询场景——一旦涉及修改,应果断转向树状数组或线段树。文末以LeetCode实战提示收束,直击算法面试中最易失分的边界细节与思维误区。

Python怎么求前缀和_一维与二维前缀和数组快速区间查询

一维前缀和:用 list 累加构造,查询靠下标减法

一维前缀和本质是把「从开头到每个位置的累加值」存下来,后续查任意区间 [l, r] 的和就不用再循环加一遍。关键不是“怎么算”,而是“下标对不对”——多数人栽在边界上。

  • prefix[i] 通常定义为 nums[0] + nums[1] + ... + nums[i-1](即 prefix[0] = 0),这样 query(l, r) 就是 prefix[r+1] - prefix[l],不用特判 l == 0
  • 别用 prefix[i] = sum(nums[:i]) 实时切片求和——时间退化成 O(n²),老老实实用一次遍历:
    prefix = [0] * (n + 1)
    for i in range(n):
      prefix[i + 1] = prefix[i] + nums[i]
  • 如果原数组下标从 1 开始(比如题目给的是 1-indexed 输入),别硬套 0-indexed 模板,先统一转成 0-indexed 再建前缀和,否则 l/r 映射错一位,结果全偏

二维前缀和:按行优先展开成二维 dp,容斥原理绕不开

二维前缀和不是“每行单独做一维”,而是把左上角 (0,0) 到当前点 (i,j) 的矩形和存下来。核心公式是:prefix[i+1][j+1] = prefix[i][j+1] + prefix[i+1][j] - prefix[i][j] + matrix[i][j]。漏掉中间的减法,整个数组就溢出。

  • 必须用 (i+1, j+1) 开辟多一行一列,让 prefix[0][*]prefix[*][0] 全为 0,否则查 (0,0)(r,c) 时要写一堆 if 判断
  • 查子矩阵 [r1, c1][r2, c2](闭区间)的和,公式固定为:prefix[r2+1][c2+1] - prefix[r1][c2+1] - prefix[r2+1][c1] + prefix[r1][c1]。记混加减顺序,结果必错;建议画个图,把四个角对应区域标出来再推
  • 初始化二维 prefix 时别用 [[0] * (m+1)] * (n+1)——这是浅拷贝,改一行全变。老实用嵌套列表推导:[[0] * (m + 1) for _ in range(n + 1)]

修改频繁?前缀和就不该上场

前缀和只适合「静态数组 + 大量查询」场景。一旦有单点修改(比如 nums[i] += x),重算整个前缀和是 O(n) 或 O(nm),比暴力还慢。

  • 需要边改边查,直接换 fenwick tree(树状数组)或 segment tree(线段树)——它们单次修改+查询都是 O(log n)
  • 真想硬用前缀和顶着改?那每次修改后必须调用完整重建函数,别只更新一个位置,否则后续所有查询都错
  • LeetCode 上标“前缀和”的题,90% 不带修改;但看到“数据流”“在线查询”“update 方法”等字眼,立刻放弃前缀和思路

Python 实现注意:别用 numpy.cumsum 替代手写

numpy.cumsum 虽快,但它返回的是新数组,且默认展平多维数组。用它做二维前缀和,要么手动 reshape 再逐行处理,要么结果维度错乱,反而更难 debug。

  • 纯 Python 场景下,手写循环比依赖 numpy 更可控、更符合算法题约束(很多 OJ 不开 numpy)
  • 如果坚持用 numpy,二维必须指定 axisnp.cumsum(matrix, axis=0) 是列方向累加,axis=1 是行方向——但这只是“行/列前缀和”,不是真正的二维矩形前缀和
  • 真正二维前缀和在 numpy 里没内置函数,硬写也得按容斥公式来,不如回归原生逻辑

实际写的时候,最常漏的是二维容斥里的那个加回项,或者一维 prefix 长度多开/少开 1。这些地方不画小例子跑两组数,光看公式根本记不住。

本篇关于《Python前缀和数组快速查询技巧》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于文章的相关知识,请关注golang学习网公众号!

微博如何查看是否被移出粉丝列表微博如何查看是否被移出粉丝列表
上一篇
微博如何查看是否被移出粉丝列表
EmailJS 发送可点击超链接教程
下一篇
EmailJS 发送可点击超链接教程
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    543次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    516次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    500次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    485次学习
查看更多
AI推荐
  • ljg-skills -
    ljg-skills
    ljg-skills 是李继刚开源的 AI 技能与提示词集合,面向大模型使用者整理了一批可复用的 prompt、角色设定和任务技能模板,适合用于学习提示词设计、搭建个人 AI 工作流和沉淀团队常用智能体能力。
    2492次使用
  • MELO音乐 - AI 音乐生成平台,支持多模态创作能力
    MELO音乐
    MELO音乐是一站式AI视频与音乐制作助手,对标suno, udio的高品质体验。提供伴奏生成、原创写词、无损导出、哼唱识曲、混音变声等全套音频与短视频编辑工具。无论是流行Kpop、电音说唱、民谣古风、摇滚儿歌还是商用轻音乐,MELO为你免费谱曲,轻松做同款!
    2301次使用
  • UniScribe - AI 免费在线音视频转文字平台
    UniScribe
    UniScribe 是一款 AI 音视频转文字与内容整理工具,支持上传音频、视频文件或粘贴 YouTube 链接,自动生成转写文本、摘要、思维导图和关键问题,并支持多格式导出,适合会议记录、课程学习、访谈整理和内容创作复盘。
    2248次使用
  • 剧云 - 免费 AI 智能中文剧本创作平台
    剧云
    剧云是专业中文剧本创作平台,安全稳定运行十余年,集成AI编剧、剧本医生审核、人物小传、剧情关系图、大纲编写、多人协作、Word导入导出、版权管控功能,数据安全防护,轻松高效创作剧本。
    2448次使用
  • 万象有声 - AI 一站式有声内容创作平台
    万象有声
    万象有声,一个专为有声创作者打造的新一代智能有声内容创作平台。平台提供专业的智能拆章、智能画本编辑、AI配音、AI生成音效、后期制作、智能对轨、智能审听等有声创作全流程工具,可以帮助创作者高效、低成本创作出引人入胜的有声作品。立即体验,让有声书制作更简单!
    2425次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码