博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
北京信息科技大学第十一届程序设计竞赛(重现赛)I
阅读量:5109 次
发布时间:2019-06-13

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

I andy种树

题目链接:

题目描述

andy在他的庄园里种了n棵树,排列成一排,标号为1到n。最开始的时候n棵树的高度都是0,也就是种子刚刚被埋下,树还没有长出来。

andy会一种魔法,他每使用一次魔法,就可以让树标号落在连续区间[l, r]里的树的高度增加1。他可以使用q次这种魔法,然后他很好奇,在使用了q次魔法之后,他的所有树的高度分别是多少呢?

输入描述:

第一行输入两个整数n,q。(1<= n, q <= 1e5) 接下来q行,每行输入两个整数l, r(l <= r),表示andy让标号落在区间[l, r]里的数高度都加1

输出描述:

输出有一行n个整数,每个整数后面有空格。输出末尾没有换行 第i个数表示第i棵树的高度
示例1

输入

10 31 32 43 3

输出

1 2 3 1 0 0 0 0 0 0

说明

andy种了10棵树 第一次使用魔法使得1、2、3棵树的高度增加1, 所有树的高度为 1 1 1 0 0 0 0 0 0 0 第二次使用魔法使得2、3、4棵树的高度增加1, 所有树的高度为 1 2 2 1 0 0 0 0 0 0 第三次使用魔法使得第3棵树的高度增加1 所有树的高度为 1 2 3 1 0 0 0 0 0 0

思路:

差分思想,建立两个数组,一个数组进行相关操作:在区间l,r中,l位置上加1,r+1位置上-1;另一个记录前缀和,前缀和数组即为所求数组

#include
typedef long long ll;using namespace std;const int maxn=2e5+7;int main(){ int n,q; cin>>n>>q; int l,r; int a[maxn]={
0},b[maxn]={
0}; while(q--) { cin>>l>>r; a[l]++; a[r+1]--; }// cout<<"a"<

 

转载于:https://www.cnblogs.com/Vampire6/p/11131753.html

你可能感兴趣的文章
yii 跳转页面
查看>>
洛谷 1449——后缀表达式(线性数据结构)
查看>>
Data truncation: Out of range value for column 'Quality' at row 1
查看>>
Dirichlet分布深入理解
查看>>
(转)Android之发送短信的两种方式
查看>>
字符串处理
查看>>
HtmlUnitDriver 网页内容动态抓取
查看>>
ad logon hour
查看>>
获得进程可执行文件的路径: GetModuleFileNameEx, GetProcessImageFileName, QueryFullProcessImageName...
查看>>
证件照(1寸2寸)拍摄处理知识汇总
查看>>
罗马数字与阿拉伯数字转换
查看>>
Eclipse 反编译之 JadClipse
查看>>
Python入门-函数
查看>>
[HDU5727]Necklace(二分图最大匹配,枚举)
查看>>
距离公式汇总以及Python实现
查看>>
设计模式之装饰者模式
查看>>
一道不知道哪里来的容斥题
查看>>
Blender Python UV 学习
查看>>
window添加右键菜单
查看>>
入手腾龙SP AF90mm MACRO
查看>>