ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

北京信息科技大学第十一届程序设计竞赛(重现赛)I

2019-07-04 13:00:24  阅读:288  来源: 互联网

标签:第十一届 int 魔法 高度 andy 重现 数组 程序设计 maxn


I andy种树

题目链接:https://ac.nowcoder.com/acm/contest/940/I

题目描述

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 3
1 3
2 4
3 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<bits/stdc++.h>
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"<<endl;
//    for(int i=1;i<=n;i++)
//        cout<<a[i]<<" ";
    b[1]=a[1];
    for(int i=2;i<=n;i++)
        b[i]=a[i]+b[i-1];
   // cout<<"b"<<endl;
    for(int i=1;i<=n;i++)
        cout<<b[i]<<" ";
    return 0;
}

 

标签:第十一届,int,魔法,高度,andy,重现,数组,程序设计,maxn
来源: https://www.cnblogs.com/Vampire6/p/11131753.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有