HDU 1566 Color the ball [树状数组区间更新]【数据结构】
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1556 Time Limit: 9000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Problem Description Input Output Sample Input Sample Output Author Source —————————————————-. 题目大意: 。。。 解题思路: 题目给的很清楚了是区间更新,所以思考。 附本题代码 #include <bits/stdc++.h>
#define abs(x) (((x)>0)?(x):-(x))
#define lalal puts("*********")
#define Rep(a,b,c) for(int a=(b);a<=(c);a++)
#define Req(a,c) for(int a=(b);a>=(c);a--)
#define Rop(a,c) for(int a=(b);a<(c);a++)
#define s1(a) scanf("%d",&a)
typedef long long int LL;
using namespace std;
const int inf = 0x3f3f3f3f;
const int MOD = 9901;
/**************************************/
#define lowbit(x) (x&-x)
const int N = 100000+5;
int sum[N];
void update(int index,int val){
for(int i=index;i<=N;i+=lowbit(i))
sum[i]+=val;
}
int getSum(int index){
int ans=0;
for(int i=index;i>0;i-=lowbit(i))
ans+=sum[i];
return ans ;
}
int main(){
int n;
while(~s1(n)&&n){
Rep(i,1,n) sum[i]=0;
int a,b;
Rep(i,n){
s1(a),s1(b);
update(a,1);
update(b+1,-1);
}
Rop(i,n) printf("%d ",getSum(i));
printf("%dn",getSum(n));
}
return 0;
}
(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |