news 2026/1/31 7:09:01

打卡信奥刷题(2716)用C++实现信奥题 P3368 【模板】树状数组 2

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
打卡信奥刷题(2716)用C++实现信奥题 P3368 【模板】树状数组 2

P3368 【模板】树状数组 2

题目描述

如题,已知一个数列,你需要进行下面两种操作:

  1. 将某区间每一个数加上xxx

  2. 求出某一个数的值。

输入格式

第一行包含两个整数NNNMMM,分别表示该数列数字的个数和操作的总个数。

第二行包含NNN个用空格分隔的整数,其中第iii个数字表示数列第 $i $ 项的初始值。

接下来MMM行每行包含222444个整数,表示一个操作,具体如下:

操作111: 格式:1 x y k含义:将区间[x,y][x,y][x,y]内每个数加上kkk

操作222: 格式:2 x含义:输出第xxx个数的值。

输出格式

输出包含若干行整数,即为所有操作222的结果。

输入输出样例 #1

输入 #1

5 5 1 5 4 2 3 1 2 4 2 2 3 1 1 5 -1 1 3 5 7 2 4

输出 #1

6 10

说明/提示

样例 1 解释:

故输出结果为666101010


数据规模与约定

对于30%30\%30%的数据:N≤8N\le8N8M≤10M\le10M10

对于70%70\%70%的数据:N≤104N\le 10^4N104M≤104M\le10^4M104

对于100%100\%100%的数据:1≤N,M≤5×1051 \leq N, M\le 5\times10^51N,M5×1051≤x,y≤n1 \leq x, y \leq n1x,yn,保证任意时刻序列中任意元素的绝对值都不大于2302^{30}230

C++实现

#include<bits/stdc++.h>usingnamespacestd;constintN=5e5+10;intn,m,a[N];longlongc[N];// 注意 c 中的值可能超过 int 范围intlowbit(intx){returnx&(-x);}voidadd(intx,intk){// 修改操作while(x<=n){c[x]+=k;x+=lowbit(x);}return;}longlongsum(intx){// 查询操作longlongres=0;while(x){res+=c[x];x-=lowbit(x);}returnres;}intmain(){cin>>n>>m;for(inti=1;i<=n;++i){cin>>a[i];add(i,a[i]-a[i-1]);// 按照差分含义初始化}while(m--){intop;cin>>op;if(op==1){intl,r,k;cin>>l>>r>>k;add(l,k),add(r+1,-k);// 差分操作}else{intx;cin>>x;cout<<sum(x)<<"\n";// 前 x 个数的和}}return0;}

后续

接下来我会不断用C++来实现信奥比赛中的算法题、GESP考级编程题实现、白名单赛事考题实现,记录日常的编程生活、比赛心得,感兴趣的请关注,我后续将继续分享相关内容

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/29 23:03:36

MySQL 8 环境中创建业务相关的数据库和关联表

文章目录 一、连接 MySQL 容器 二、创建数据库(UTF8mb4) 三、创建关联表(带外键,适合多表查询) 四、插入测试数据 五、多表查询核心练习(按场景分类) 场景1:基础内连接(INNER JOIN)—— 查“有订单的用户+订单信息” 场景2:左连接(LEFT JOIN)—— 查“所有用户+订…

作者头像 李华
网站建设 2026/1/30 18:45:36

单片机光伏太阳能锂电池发电手机充电器防过充无线充电输出设计(设计源文件+万字报告+讲解)(支持资料、图片参考_相关定制)_文章底部可以扫码

21-041、51单片机光伏太阳能锂电池发电手机充电器防过充无线充电输出设计产品功能描述&#xff1a; 本系统由STC89C52单片机、LCD1602液 晶显示、锂电池充电检测、太阳能发电、锂电池充电保护TP4056、升压稳压、无线充电模块组成。 1、通过太阳能电池板并接给锂电池供电&#x…

作者头像 李华
网站建设 2026/1/29 23:13:35

51单片机地震震动检测语音报警器检测系统131(设计源文件+万字报告+讲解)(支持资料、图片参考_相关定制)_文章底部可以扫码

51单片机地震震动检测语音报警器检测系统131产品功能描述&#xff1a; 本系统由STC89C52单片机、语音模块、短接检测及电源组成。 1、如果两根线短接了&#xff0c;则语音一直报警。除非按下复位按键或者断开电源&#xff0c;则语音不报警。 2、该设备可以作为简单震动报警器或…

作者头像 李华
网站建设 2026/1/30 11:46:25

导师严选10个AI论文工具,助继续教育学生轻松写论文!

导师严选10个AI论文工具&#xff0c;助继续教育学生轻松写论文&#xff01; AI 工具如何助力论文写作&#xff1f; 在当前继续教育学生面临日益繁重的学术任务背景下&#xff0c;AI 工具正逐渐成为不可或缺的得力助手。无论是撰写开题报告、构建论文大纲&#xff0c;还是完成初…

作者头像 李华