当前位置: 首页 > news >正文

asp 网站运行网站建设南阳

asp 网站运行,网站建设南阳,建筑方案设计说明,做跨境的网站有哪些内容题目描述 如题,已知一个数列 {ai}\{a_i\}{ai​},你需要进行下面两种操作: 将某区间每一个数加上 kkk。求出某区间每一个数的和。 输入格式 第一行包含两个整数 n,mn, mn,m,分别表示该数列数字的个数和操作的总个数。 第二行包含 n…

题目描述

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

  1. 将某区间每一个数加上 kkk
  2. 求出某区间每一个数的和。

输入格式

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

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

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

  1. 1 x y k:将区间 [x,y][x, y][x,y] 内每个数加上 kkk
  2. 2 x y:输出区间 [x,y][x, y][x,y] 内每个数的和。

输出格式

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

输入输出样例 #1

输入 #1

5 5
1 5 4 2 3
2 2 4
1 2 3 2
2 3 4
1 1 5 1
2 1 4

输出 #1

11
8
20

说明/提示

对于 15%15\%15% 的数据:n≤8n \le 8n8m≤10m \le 10m10
对于 35%35\%35% 的数据:n≤103n \le {10}^3n103m≤104m \le {10}^4m104
对于 100%100\%100% 的数据:1≤n,m≤1051 \le n, m \le {10}^51n,m105ai,ka_i,kai,k 为正数,且任意时刻数列的和不超过 2×10182\times 10^{18}2×1018

【样例解释】

solution

线段树是一种常用的数据结构,实现区间查询和区间修改,时间和空间复杂度都是O(nlogn)O(nlogn)O(nlogn)
其基本原理是用一个二叉树点维护一个区间的数据,然后它的两个字节点各负责半个区间,将统计信息汇总给该节点

代码

#include <sstream>
#include "iostream"
#include "cmath"
#include "vector"
#include "algorithm"using namespace std;
const int N = 1e5 + 5;int n;
long long b[N];struct node {long long sum, tag;
} a[4 * N];// 将父节点的 tag 信息向下分摊
void push_down(int rt, int l, int r) {int m = r + l >> 1;a[rt * 2].sum += a[rt].tag * (m - l + 1);a[rt * 2].tag += a[rt].tag;a[rt * 2 + 1].sum += a[rt].tag * (r - m);a[rt * 2 + 1].tag += a[rt].tag;a[rt].tag = 0;
}void push_up(int rt) {a[rt].sum = a[rt * 2].sum + a[rt * 2 + 1].sum;
}void build(int rt, int l, int r) {a[rt].tag = 0;if (l == r) {a[rt].sum = b[l];return;}int m = l + r >> 1;build(rt * 2, l, m);build(rt * 2 + 1, m + 1, r);push_up(rt);
}void update(int rt, long long k, int l, int r, int L, int R) { // l, r 是 rt管理的区间, L R是修改的区间, k 是修改的量// 整个区间都要增加kif (L <= l && r <= R) {a[rt].sum += (r - l + 1) * k;a[rt].tag += k;return;}push_down(rt, l, r); // tag 向下传递int m = l + r >> 1;if (L <= m) update(rt * 2, k, l, m, L, R);if (R > m) update(rt * 2 + 1, k, m + 1, r, L, R);push_up(rt); // sum 向上汇总
}long long query(int rt, int l, int r, int L, int R) {// 整个区间都要if (L <= l && r <= R) {return a[rt].sum;}push_down(rt, l, r);int m = l + r >> 1;long long s = 0;if (L <= m) s += query(rt * 2, l, m, L, R);if (R > m) s += query(rt * 2 + 1, m + 1, r, L, R);return s;
}int main() {int m;cin >> n >> m;for (int i = 1; i <= n; i++) cin >> b[i];build(1, 1, n);for (int i = 0; i < m; i++) {int op, l, r;long long k;cin >> op >> l >> r;if (op == 1) {cin >> k;update(1, k, 1, n, l, r);} else {cout << query(1, 1, n, l, r) << endl;}}}

结果

在这里插入图片描述

http://www.dtcms.com/a/434103.html

相关文章:

  • 自贡网站建设公司智能制造
  • 建站交流自己的网站怎么做搜索引擎
  • 怎么查询网站的设计公司怎么看一个网站有没有做301
  • 建设银行公户网站服务商类型是什么意思
  • 余干县建设局网站学校seo推广培训班
  • 小型网站建设需要多少钱dedecms 资源类网站模板
  • 做销售在哪个网站找客户端wordpress linux 配置
  • 长治网站制作网站开发专业的建设设想
  • 网站内容建设是什么wordpress电商ar
  • 电商网站商品中心设计方案网站优化 套站
  • 东莞网站制作外包湖南郴州建设局网站
  • 个人网站项目策划书seo相关ppt
  • 网站制作哪个公司好湖南云网站建设
  • 网站建设公司 广告法被处罚移动app开发技术
  • 二级网站都在一台服务器怎么做域名用了wordpress的网站
  • 先进的网站开发技术海南省建设集团有限公司网站
  • 网线制作考核标准sem和seo的区别
  • 网站流量是如何计算的网站页面字体设置
  • 做城通网盘资源网站的源码品牌建设 高质量发展
  • 秦州区建设局网站自己建网站 wordpress
  • 怎么用网站源码建站代刷网站是怎么做的
  • 如何做一个导航网站做网络推广可以通过哪些渠道推广
  • 常德地区网站建设wordpress云主机模板
  • 如何做国外的电商网站珠海网站建设优化
  • 如何做好一个企业网站设计给宝宝做辅食的网站
  • ftp怎么上传网站做网站和服务器的大小有关吗
  • 绍兴市建设银行网站物流管理系统
  • 网站建设采购公告模板网站 动易
  • 单页面网站如何seo网站上加一个浮动小框怎么做
  • 广东模板网站建设报价湛江网络营销