杭电Color the ball1556

原创 2015年11月19日 19:46:43

Color the ball

Time Limit: 9000/3000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 13689    Accepted Submission(s): 6875


Problem Description
N个气球排成一排,从左到右依次编号为1,2,3....N.每次给定2个整数a b(a <= b),lele便为骑上他的“小飞鸽"牌电动车从气球a开始到气球b依次给每个气球涂一次颜色。但是N次以后lele已经忘记了第I个气球已经涂过几次颜色了,你能帮他算出每个气球被涂过几次颜色吗?
 

Input
每个测试实例第一行为一个整数N,(N <= 100000).接下来的N行,每行包括2个整数a b(1 <= a <= b <= N)。
当N = 0,输入结束。
 

Output
每个测试实例输出一行,包括N个整数,第I个数代表第I个气球总共被涂色的次数。
 

Sample Input
3 1 1 2 2 3 3 3 1 1 1 2 1 3 0
 

Sample Output
1 1 1 3 2 1
 
#include <string.h> #include <stdio.h> const int SIZE = 100005; int tree[SIZE]; inline int lowbit(int x) {  return x & (-x); } void update(int x, int val, int len) {  while (x <= len)  {   tree[x] += val;   x += lowbit(x);  } } int query(int x) {  int ans = 0;  while (x > 0)  {   ans += tree[x];   x -= lowbit(x);  }  return ans; } int main() {  int n, a, b;  while (scanf("%d", &n) && n != 0)  {    memset(tree,0,sizeof(tree));    for(int i = 0; i < n; i++)    {     scanf("%d%d",&a,&b);     update(a,1, n);     update(b+1,-1, n);    }    for(int i=1;i<n;i++)    {     printf("%d ",query(i));    }    printf("%d\n",query(n));   }  return 0; }
 
版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

杭电1556 Color the ball

Color the ball Time Limit: 9000/3000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...

Color the ball - HDU 1556 - 线段树 区间更新单点查询

Color the ball - HDU 1556 - 线段树 区间更新单点查询  国际惯例中文题目不解释,思路直接裸线段树,Lazy思想入门题。  Lazy传送门:延迟更新详解AC代码:// // ...

HDU 1556 Color the ball(线段树区间更新区间查询模板)

Problem Description N个气球排成一排,从左到右依次编号为1,2,3....N.每次给定2个整数a b(a   Input 每个测试实例第一行为一个整数N,(N ...

HDU1556 Color the ball 解题报告--线段树

Color the ball Time Limit: 9000/3000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...

HDoj-1556-Color the ball-树状数组

NEW~ 关于举办计算机学院大学生程序设计竞赛(2014'11)的报名通知 Color the ball Time Limit: 9000/3000 MS (Java/Others)    ...

hdu 1556 Color the ball

Color the ball Time Limit: 9000/3000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...

HDU1556 Color the ball(线段树区间更新)

Color the ball Time Limit: 9000/3000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...

hdu 1556 Color the ball

这个题我提交了十几遍,一开始不明白为什么区间更新和定点更新的函数一样结果却不一样,不过后来才知道区间更新中最下面的一排数是与前一个数相比增加了多少。就相当于更新4到6区间,还是给4加x,给6减x,中间...

【线段树II:区间修改+点查询】hdu 1556 Color the ball

【线段树】hdu 1556 Color the ball题目链接:hdu 1556 Color the ball题目大意给你N个气球,不断刷新指定区间的颜色,刷新N次,最后输出每一个气球的刷新次数。上...

HDOJ 1556 Color the ball(树状数组 & 线段树)

Color the ball Time Limit: 9000/3000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)