【算法】前缀和(一)原理

【算法】前缀和(一)原理

目录

一、题目描述

二、算法原理

动态规划

1.前缀和

1.1同类累

1.2所有路出

三、提交代


一、题目描述

【模板】前缀和_牛客题霸_牛客网

描述

对于给定的长度为 nn 的数组 {a1,a2,…,an}{a1​,a2​,…,an​} ,我们有 mm 次查询操作,每一次操作给出两个参数 l,rl,r ,你需要输出数组中第 ll 到第 rr 个元素之和,即 al+al+1+⋯+aral​+al+1​+⋯+ar​ 。

输入描述:

第一行输入两个整数 n,m(1≦n,m≦105)n,m(1≦n,m≦105) 代表数组中的元素数量、查询次数。

第二行输入 nn 个整数 a1,a2,…,an(−109≦ai≦109)a1​,a2​,…,an​(−109≦ai​≦109) 代表初始数组。

此后 mm 行,每行输入两个整数 l,r(1≦l≦r≦n)l,r(1≦l≦r≦n) 代表一次查询。

输出描述:

对于每一次查询操作,在一行上输出一个整数,代表区间和。

示例

输入:

3 2 1 2 4 1 2 2 3

输出:

3 6


二、算法原理动态规划

同类累积问题 可 所有路出1.前缀和

1.1同类累积

前缀区间和= 再前缀区间和 + 当前数(dp[i] = dp[i - 1] + arr[i])1.1.1拆拼

整体 拆成 能同类累积部分拼合成:

238. 除自身以外数组的乘积 - 力扣(LeetCode)

给你一个整数数组 nums,返回 数组 answer ,其中 answer[i] 等于 nums 中除 nums[i] 之外其余各元素的乘积 。

题目数据 保证 数组 nums之中任意元素的全部前缀元素和后缀的乘积都在  32 位 整数范围内。

请 不要使用除法,且在 O(n) 时间复杂度内完成此题。

示例 1:输入: nums = [1,2,3,4] 输出: [24,12,8,6]

示例 2:输入: nums = [-1,1,0,-3,3] 输出: [0,0,9,0,0]

提示:2 <= nums.length <= 105-30 <= nums[i] <= 30输入 保证 数组 answer[i] 在  32 位 整数范围内

1.2所有路出

所有前缀区间和一路累积算出

三、提交代码

public static void main(String[] args) { Scanner in = new Scanner(System.in); int n = in.nextInt(), m = in.nextInt(); int[] array = new int[n + 1]; for(int i = 1;i <= n;i++) array[i] = in.nextInt(); // 所有前缀和累积算出 long[] dp = new long[n + 1]; for(int i = 1;i <= n;i++) dp[i] = dp[i - 1] + array[i]; while(m > 0) { int l = in.nextInt(), r = in.nextInt(); System.out.println(dp[r] - dp[l - 1]); m--; } }

Read more

【Claude Code】无需sudo!无魔法!Linux 普通用户也能装 Claude Code 全流程

【Claude Code】无需sudo!无魔法!Linux 普通用户也能装 Claude Code 全流程

🐧 无需 sudo!无魔法!Linux 普通用户也能装 Claude Code 全流程 🚀 环境:Ubuntu / CentOS / Arch 等任意发行版 权限:❌ 不需要 root,❌ 不需要 sudo,✅ 只要你能登录就行! 文章目录 * 🐧 无需 sudo!无魔法!Linux 普通用户也能装 Claude Code 全流程 🚀 * 🌈 最终效果 * 📦 1. 准备用户级目录 * 🔍 2. 一键获取“最新 20.x LTS”真实下载地址 * ⬇️ 3. 下载 + 解压(一条命令搞定) * 📁 4. 把 Node 塞进自己的 PATH * 🪣 5. 给 npm

By Ne0inhk
Linux 文件描述符与重定向实战:从原理到 minishell 实现

Linux 文件描述符与重定向实战:从原理到 minishell 实现

🔥草莓熊Lotso:个人主页 ❄️个人专栏: 《C++知识分享》《Linux 入门到实践:零基础也能懂》 ✨生活是默默的坚持,毅力是永久的享受! 🎬 博主简介: 文章目录 * 前言: * 一. 文件描述符(fd):Linux IO 的 “身份证” * 1.1 什么是文件描述符? * 1.2 默认文件描述符:0、1、2 * 1.3 文件描述符的分配规则 * 1.4 系统调用与库函数的关系 * 二. 重定向原理:修改 fd 对应的文件对象 * 2.1 重定向的本质 * 2.2 手动实现重定向:close+open * 2.3

By Ne0inhk

飞书 × OpenClaw 接入指南:不用服务器,用长连接把机器人跑起来

你想在飞书里用上一个能稳定对话、能发图/收文件、还能按规则在群里工作的 AI 机器人,最怕两件事:步骤多、出错后不知道查哪里。这个项目存在的意义,就是把“飞书接 OpenClaw”这件事,整理成一套对非技术也友好的配置入口,并把官方文档没覆盖到的坑集中写成排查清单。 先说清楚它的角色:OpenClaw 现在已经内置官方飞书插件 @openclaw/feishu,功能更完整、维护也更及时。这是好事,说明飞书 + AI 的接入已经走通。这个仓库并不是要替代官方插件,而是继续为大家提供: * 新用户:从零开始的新手教程(15–20 分钟) * 老用户:从旧版(独立桥接或旧 npm 插件)迁移到官方插件的保姆级路线 * 常见问题答疑 & 排查清单(最常见的坑优先) * 进阶场景:独立桥接模式依然可用(需要隔离/定制时再用) 另外,仓库也推荐了一个新项目

By Ne0inhk
Windows 环境下金仓 KingbaseES数据库部署指南:从硬件适配到组件运维的专业范式

Windows 环境下金仓 KingbaseES数据库部署指南:从硬件适配到组件运维的专业范式

引言 在近些年信息技术的飞速发展与数字化转型的加速,数据库作为信息系统的核心,其兼容性、性能与稳定性直接关系到业务系统的连续性和演进能力。而KingbaseES一直走在数据库自主创新的道路上不断前进,现如今国产化替代最优选择之一,具有良好的社区生态,深度兼容性。下面博主就来详细介绍一下开发者如何快速部署金仓 KingbaseES数据库。 文章目录 * 引言 * 一、安装前准备工作 * 1.1 硬件环境要求 * 1.2 软件环境要求 * 1.3 下载安装包 * 1.2 检验安装包是否完整 * 二、 开始图形化界面安装 * 2.1 点击图形化安装程序 * 2.2 接受许可协议 * 2.3 选择授权文件 * 2.4 选择安装路径 * 2.5 选择安装集 * 2.6 安装预览 * 2.7 等待安装进度

By Ne0inhk