博客
关于我
【ACWing】797. 差分
阅读量:223 次
发布时间:2019-02-28

本文共 1327 字,大约阅读时间需要 4 分钟。

题目地址:

给定一个长 n n n的整数序列 A A A,再进行 m m m次操作,每次操作包含三个整数 l , r , c l,r,c l,r,c,表示将序列中的 [ l , r ] [l,r] [l,r]每个数都增加 c c c。输出操作完后的数列。区间的下标是从 1 1 1开始计数的。

输入格式:

第一行包含两个整数 n n n m m m。第二行包含 n n n个整数,表示整数序列。接下来 m m m行,每行包含三个整数 l l l r r r c c c,表示一个操作。

输出格式:

共一行,包含 n n n个整数,表示最终序列。

数据范围:

1 ≤ n , m ≤ 100000 1\le n,m\le 100000 1n,m100000
1 ≤ l ≤ r ≤ n 1\le l\le r\le n 1lrn
− 1000 ≤ c ≤ 1000 -1000\le c\le 1000 1000c1000
− 1000 ≤ A [ i ] ≤ 1000 -1000\le A[i]\le 1000 1000A[i]1000

思路是利用差分数组。求出差分数组 d d d使得 A [ i ] = ∑ d [ 0 : i ] A[i]=\sum d[0:i] A[i]=d[0:i]真实代码中可以想象 A A A一开始都是 0 0 0,每次将 A [ i : i ] A[i:i] A[i:i]增加一个数,而对于差分数组来说,原数组 A [ l : r ] A[l:r] A[l:r]全体增加一个数 c c c,效果是 d [ l ] d[l] d[l]增加 c c c,而 d [ r + 1 ] d[r+1] d[r+1]减少 c c c(如果 r + 1 r+1 r+1越界了那就忽略),这样方便编程。代码如下:

#include 
using namespace std;const int N = 100010;int a[N], d[N];int n, m, l, r, c;int main() { cin >> n >> m; for (int i = 0; i < n; i++) cin >> a[i]; for (int i = 0; i < n; i++) { d[i] += a[i]; if (i + 1 < n) d[i + 1] -= a[i]; } while (m--) { cin >> l >> r >> c; d[l - 1] += c; d[r] -= c; } int s = 0; for (int i = 0; i < n; i++) { s += d[i]; printf("%d ", s); } return 0;}

时间复杂度 O ( n + m ) O(n+m) O(n+m),空间 O ( n ) O(n) O(n)

转载地址:http://cijs.baihongyu.com/

你可能感兴趣的文章
Nginx多域名,多证书,多服务配置,实用版
查看>>
nginx如何实现图片防盗链
查看>>
Nginx学习总结(11)——提高Nginx服务器的安全性,稳定性和性能的12种技巧
查看>>
Nginx学习总结(12)——Nginx各项配置总结
查看>>
Nginx学习总结(13)——Nginx 重要知识点回顾
查看>>
Nginx学习总结(14)——Nginx配置参数详细说明与整理
查看>>
Nginx学习总结(15)—— 提升 Web 应用性能的十个步骤
查看>>
Nginx学习总结(8)——Nginx服务器详解
查看>>
nginx学习笔记002---Nginx代理配置_案例1_实现了对前端代码的方向代理_并且配置了后端api接口的访问地址
查看>>
Nginx安装SSL模块 nginx: the “ssl” parameter requires ngx_http_ssl_module in /usr/local/nginx/conf/nginx
查看>>
nginx安装stream模块配置tcp/udp端口转发
查看>>
nginx安装Stream模块配置tcp/udp端口转发
查看>>
Nginx安装与常见命令
查看>>
nginx安装与配置
查看>>
Nginx安装及配置详解
查看>>
nginx安装并配置实现端口转发
查看>>
nginx安装配置
查看>>
Nginx实战之1.1-1.6 Nginx介绍,安装及配置文件详解
查看>>
Nginx实战经验分享:从小白到专家的成长历程!
查看>>
nginx实现二级域名转发
查看>>