HDU 1541+poj 2352 stars

Stars

题目链接:点击打开链接


本题是树状数组模板题,由于x,y数据过大,不能开二维数组;但是题目中说了数据是一维一维的给出的所以可以用一维数组;

还有一点就是x可以为0,所以对于所有x都加1处理;


代码如下:

#include<stdio.h>
#include<string.h>
#define MAXN 32002
#define N 15002
int tree[MAXN];
int vi[N];
int n;
void add(int x,int num)
{
	for(int i=x;i<MAXN;i+=i&-i)
		tree[i]+=num;
}
int read(int x)
{
	int sum=0;
	for(int i=x;i>0;i-=i&-i)
		sum+=tree[i];
	return sum;
}
int main()
{
	int x,y;
	while(~scanf("%d",&n))
	{
		memset(vi,0,sizeof(vi));
		memset(tree,0,sizeof(tree));
		for(int i=0;i<n;i++)
		{
			scanf("%d%d",&x,&y);
			vi[read(++x)]++;
			add(x,1);
		}
		for(int i=0;i<n;i++)
        	printf("%d\n",vi[i]);
	}
	return 0;
}


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值