EOJ Problem #1076

题目描述:

小强和旺财去逛街,他们去了欧尚,旺财看见超市里面的气球兴奋的直叫,呵呵,由于小强很喜欢旺财,所以下定决心给旺财买一打回家。回家小强数了下,一共有 N 只气球,小强将 N 只气球从左到右依次编号为 1、2、3……N,每次给 2 个整数 a,b (a<=b),小强便骑上他的“小飞鸽 ” 牌电动车从气球 a 开始到气球 b 依次给每个气球涂一次颜色。但是 N 次以后小强已经忘记了第 I 个气球已经涂过几次颜色了,你能帮他算出每个气球被涂过几次颜色吗?

输入格式:

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

当 N = 0,输入结束。

输出格式:

每个测试实例输出一行,包括 N 个整数,第 I 个数代表第 I 个气球总共被涂色的次数。注意,每个数据之间有个空格,最后一个数据后面没空格。

样例:

Input
3
1 1
2 2
3 3
3
1 1
1 2
1 3
0
Output

1 1 1

3 2 1

思路分析:

本题可以通过遍历的方式暴力求解,但测试一定会超时。因此,需要换一种方法。

每行输入两个数a,b分别表示起点和终点,因为可以在这两点(起点,终点后一位)分别做两次标识即可,在起点+1,遇到终点后一位-1(终点依然需要计算)。

代码:

using namespace std;

int main(){
    int i,n,a,b;

    while(scanf("%d",&n) && n){
        int result = 0;
        int arr[100001] = {0};
        int k = n;
        while(k--){
            scanf("%d%d",&a,&b);
            arr[a]++;
            arr[b + 1]--;
        }
        for(i = 1; i < n; i++){
            result += arr[i];
            cout << result << " ";
        }
        result += arr[i];
        cout << result << endl;
    }
    return 0;
}

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值