poj2352 starts 树状数组

有n个星星,按照y坐标的升序给出n个星星的坐标,

对于每一个星星,其level为在其左下方(包括正左,正下)的星星个数,输出n行,第i行代表等级为i个星星的星星的个数。

树状数组的插点问段

思路:

a[i] 存储星星的x坐标,

b[i] 表示0到i中x,y坐标小于i的个数,即i的等级

则对于每个b[i], 做一次扫描

ans[i] 表示等级为i的个数

则ans[b[i]]++;

明显,这样肯定tle。

所以要采用树状数组 。

a[i] 表示目前的星星中x坐标为i的个数

c[i] 为a[i]的树状数组

sum[i]表示坐标为1到i的个数的和,即为等级。

ans[i] 表示等级为i的个数。

4个数组,实际上只需要维护2个,c[i]和ans[i]。

注意一,这道题的输入,x和y是可以为0的,所以x统一加一,不然很麻烦。

注意二:这道题的启示,对于2维的,有时候可以对其中1维排序,转化成1维的来解决。

 1 #include<cstdio>
 2 #include<algorithm>
 3 #include<cstring>
 4 using namespace std;
 5 const int MAXN=32000+10;
 6 int c[MAXN];
 7 int ans[MAXN];
 8 int lowbit(int x)
 9 {
10     return x&(-x);
11 }
12 void update(int x,int add)
13 {
14     while(x<=MAXN){
15         c[x]+=add;
16         x+=lowbit(x);
17     }
18 }
19 int sum(int x)
20 {
21     int temp=0;
22     while(x>0){
23         temp+=c[x];
24         x-=lowbit(x);
25     }
26     return temp;
27 }
28 int main()
29 {
30     int n;
31     while(scanf("%d",&n)!=EOF){
32         memset(ans,0,sizeof(ans));
33         memset(c,0,sizeof(c));
34         int i,j;
35         for(int t=0;t<n;t++){
36             scanf("%d%d",&i,&j);
37             i++;
38             ans[sum(i)]++;
39             update(i,1);
40         }
41         for(int i=0;i<n;i++)
42             printf("%d\n",ans[i]);
43     }
44     return 0;
45 }

时间: 2024-08-28 05:09:22

poj2352 starts 树状数组的相关文章

POJ2352 Stars 树状数组

POJ2352 非常裸的树状数组的题. 注意数组下标不能从0开始 因为lowbit(0)==0 所以 所有横坐标统一加1 数组要开的够大 就酱 #include<cstdio> #include<iostream> #include<cstdlib> #include<cstring> #include<cmath> #include<vector> using namespace std; const int maxn=15000,

poj--2352 Stars(树状数组)

Description Astronomers often examine star maps where stars are represented by points on a plane and each star has Cartesian coordinates. Let the level of a star be an amount of the stars that are not higher and not to the right of the given star. As

POJ2352(树状数组)

Stars Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 33786   Accepted: 14741 题目链接:http://poj.org/problem?id=2352 Description Astronomers often examine star maps where stars are represented by points on a plane and each star has Cartesia

POJ2352 Stars 【树状数组】or【线段树】

Stars Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 31172   Accepted: 13595 Description Astronomers often examine star maps where stars are represented by points on a plane and each star has Cartesian coordinates. Let the level of a st

POJ2352题解(树状数组)

POJ2352题解(树状数组) 2019-12-29 Powered by Gauss 1.题目传送门:POJ2352 2.题目大意: 这是一道非常经典的树状数组的模板题. 题目大意是说,给出N颗星星,每个星星都有一个二维坐标,要求出位于每颗星星左下方的星星的数量. 3.算法思路: 这道题被给出之后立刻想到暴力法,让我们来计算一下: 根据题目,N<=15000,暴力法需要双层循环,也就是150002=225,000,000,超出了一秒,所以不得不寻求更快更好的算法思想. 当我们需要求查询,求和的

树状数组POJ2352星星

http://poj.org/problem?id=2352 这道题的题意对于住学者应该比较难理解,但是如果弄明白他的意思的话,你就会发现这就是赤裸裸的树状数组,哎,欺负我不懂是吧,当时读题读啦好久,好啦,下面说一下他的意思吧.. 由于题目已经说明y的坐标是递增顺序,所以直接考虑x的坐标就可以啦.每次当有x输入时,都求出sum(x+1)的值(注意呦,在树状数组中,可是从1开始的,而题目中的输入是包含0的),并把result[sum(x+1)]++:再更新一下,就好啦啦啦啦. 还是要注意一点,用c

poj2352树状数组

Astronomers often examine star maps where stars are represented by points on a plane and each star has Cartesian coordinates. Let the level of a star be an amount of the stars that are not higher and not to the right of the given star. Astronomers wa

[ACM] POJ2352 [树状数组稍微变形]

Description Astronomers often examine star maps where stars are represented by points on a plane and each star has Cartesian coordinates. Let the level of a star be an amount of the stars that are not higher and not to the right of the given star. As

POJ 2481 树状数组 区间覆盖(POJ2352 Stars 的变形题)(线段化点)

0)学会将题目情景转化为自己熟悉的结构或模型. 题目大意: 每个奶牛有自己的一个区间,求每个奶牛的区间所覆盖的子区间个数(注意,真子集,相等的不算),按照输入的顺序输出. 转化: 要学会将题目情景转化为自己熟悉的模型或结构上.把每个区间的左端x值作为点的x坐标,右端x值作为点的y坐标,就可以把所有区间转化为一个二维坐标图上的点集,而此时每个点左上方的点(同Stars那道题目一样不包括自身)的个数,就是每个区间所覆盖的子区间的个数(对应题目要求,这里或许可以再变形). 同POJ2481 Stars