Poj 2352 Star

本文介绍了如何通过树状数组或线段树实现计算星星等级的算法,详细解释了算法逻辑,并提供了代码实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  计算星星的等级,星星左下方的其他星星的数目就是那颗星星的等级(可以在同一水平线或竖直线上),由于y、x是递增给出的,第y层增加减少星星数目对y-1层毫无影响。每增加一颗星星(x,y),只需要统计[1-x]区间星星的数目,就能得到它的level值,另外要更新x之后的数组。算法是用树状数组实现的,也可以用线段树,代码如下:
 1 #include <iostream>
 2 #include <cstdio>
 3 using namespace std;
 4 #define Max 32010
 5 int star[Max];
 6 int level[Max];
 7 int Lowbit(int x);
 8 int Sum(int k);
 9 void Update(int k);
10 int main()
11 {
12     //freopen("D:\\acm.txt","r",stdin);
13     int xNum = 0, yNum = 0;
14     int lineNum = 0;
15     scanf("%d",&lineNum);
16     for (int i = 0; i < lineNum; ++i){
17         scanf("%d%d", &xNum, &yNum);
18         level[Sum(xNum + 1)]++;//xNum要加1或者一个正整数,避免为0,否则会报错
19         Update(xNum + 1);
20     }
21     for (int i = 0; i < lineNum; ++i)
22         printf("%d\n",level[i]);
23     return 0;
24 }
25 int Lowbit(int x){
26     return x & (-x);//返回最后一个1的位置开始的数
27 }
28 int Sum(int k){  //前k项和
29     int judge = 0;
30     while (k){
31         judge = judge + star[k];
32         k = k - Lowbit(k);//
33     }
34     return judge;
35 }
36 void Update(int k){//修改第k项,更新之后的内容
37     while (k < Max){
38         star[k]++;
39         k = k + Lowbit(k);
40     }
41 }

附上线段树解决方案(不是我写的),留作以后学习。现在基本是看懂代码,理解思想,真正自己是想不到的,继续努力!

http://blog.chinaunix.net/uid-22263887-id-1778936.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值