题目地址: http://poj.org/problem?id=2352

分析:

  - 题意分析:  有n个星星, 它的左下方(x和y不超过它)的星星的数目就是它的level, 分别计算level 为 0 到 n-1 的星星的数目. 输入是先按照 y 从小到大排序, 如果y相同,就按照x递增排序, 不会有2个以上星星占同一个坐标.

  - 数据结构

    - 用原始数据数组 a 表示同一个x坐标的星星数目. (a[i]为x坐标为 i-1的星星数目).  注意输入数据时排序的.

    - 树状数组s维护a的信息.

    - level: level[i] 记录 level为i的星星的数目.

  - 计算

    - 树状数组构建: 由于输入是先按照y排序, 再按照x排序的, 所以不用数组a来构建(最开始a为全0, s也为全0), 而是直接根据输入从无到有更新.

    - 计算level: sumn(int x) 计算了x坐标不大于x的星星的个数, 而按照输入, 计算的时候y值大于当前星星的星星还没有被输入. 所以这个数目就是当前星星的level, 而后面输入的y值不会比这个小, 所以后面的输入, 对当前星星的level不会有改变.

#include <iostream>
#include <cstring>
using namespace std; #define MAX_INDEX_RANGE 32010 // index is from 1. // 原始数据数组是隐藏的, a[i] 表示x坐标为i的星星数目.
// s 为维护a数组的树状数组.下标从1 开始.
int s[MAX_INDEX_RANGE];
// level[i] 表示level为i的星星的数目.
int level[MAX_INDEX_RANGE]; int lowbit(int x){
return x & (-x);
} // 计算x坐标不超过x的星星的总数. 由于是树状数组是动态构建的, 按照输入顺序, y值大于当前星星的还没有被输入, 所以这个数目就是位于当前星星左下方的数目.
int sumn(int x){
int sum = ;
while(x > ){
sum += s[x];
x -= lowbit(x);
}
return sum;
} //N: 总的星星的实际数目.
void modify(int n,int delta,int N){
// 注意: s[i]的范围是星星坐标的最大值, 因为原始数据数组a表示的是x坐标.
while(n <= MAX_INDEX_RANGE){
s[n] += delta;
n += lowbit(n);
}
} int main(){
int N,x,y,i;
while(cin>>N){
memset(s,,sizeof(s));
memset(level,,sizeof(level));
for(i=;i<N;++i){
cin>>x>>y;
x++; // 因为树状数组坐标从1开始.
level[sumn(x)]++;
modify(x,,N);
}
for(i=;i<N;++i){
cout<<level[i]<<endl;
}
}
return ;
}

总结:

  - 题目中关键在于找出一维数组a[i]来记录x坐标为 i 的星星的数目. 根据分析, 要求出某个星星左下方的星星数目, 只需求出当前(在它坐标输入的时候)x坐标小于它的星星的数目即可, 也就是要随时查询 x坐标小于等于它的x坐标的星星数目的和. 正好可以用树状数组的统计功能对当前的a[]进行统计.

  - 树状数组 s 作为一种数据结构比较抽象,没有实际的意义, 仅仅是方便对原始数据数组进行统计和维护.

  - 树状数组可以用作原始数据数组, 因为s[i]一定包含a[i], 要求a[i] 只需通过计算即可算出来 sumn(i) - sumn(i-1).


-->

树状数组 - 2352 Stars的更多相关文章

  1. 【POJ2352】【树状数组】Stars

    Description Astronomers often examine star maps where stars are represented by points on a plane and ...

  2. 树状数组 poj2352 Stars

    2019-05-20 22:52:07 加油,坚持,加油,坚持 !!! #include<iostream> #include<cstdio> #include<cstr ...

  3. POJ 2352 Stars(树状数组)

    Stars Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 30496   Accepted: 13316 Descripti ...

  4. hdu 1541/poj 2352:Stars(树状数组,经典题)

    Stars Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submi ...

  5. POJ 2352 &amp;&amp; HDU 1541 Stars (树状数组)

    一開始想,总感觉是DP,但是最后什么都没想到.还暴力的交了一发. 然后開始写线段树,结果超时.感觉自己线段树的写法有问题.改天再写.先把树状数组的写法贴出来吧. ~~~~~~~~~~~~~~~~~~~ ...

  6. 【树状数组】POJ 2352 Stars

    /** * @author johnsondu * @time 2015-8-22 * @type Binary Index Tree * ignore the coordinate of y and ...

  7. POJ 2352 Stars(树状数组)题解

    Language:Default Stars Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 52268 Accepted: 22 ...

  8. POJ 2352 stars (树状数组入门经典!!!)

    Stars Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 54352   Accepted: 23386 Descripti ...

  9. 树状数组 || POJ 2352 Stars

    Astronomers often examine star maps where stars are represented by points on a plane and each star h ...

随机推荐

  1. nginx上传文件大小

    采用nginx作反向代理,出现了一个诡异的问题,小文件可以提交,大文件会报500内部错误.这个是什么原因导致的呢? 查wiki可知,上传文件大小相关的有三个配置 client_body_buffer_ ...

  2. 安装配置solr

    1.由于用户是普通用户,没有root一些权限,所以修改hadoop用户权限 用root权限,修改sudoers文件 nano    /etc/sudoers   打开文件,修改hadoop用户权限,如 ...

  3. 安装FreePBX的ISO版本

    下载地址:http://schmoozecom.com/distro-download.php 这个相当于系统了,第一步:安装程序会提示选择你想安装Asterisk的版本:现在出现了11版本,这个根据 ...

  4. hadoop性能测试

    一.hadoop自带的性能基准评测工具 (一)TestDFSIO 1.测试写性能 (1)若有必要,先删除历史数据 $hadoop jar /home/hadoop/hadoop/share/hadoo ...

  5. django之jquery完成ajax

    使用Ajax 使用视图通过上下文向模板中传递数据,需要先加载完成模板的静态页面,再执行模型代码,生成最张的html,返回给浏览器,这个过程将页面与数据集成到了一起,扩展性差 改进方案:通过ajax的方 ...

  6. 前端学习---JavaScript

    JavaScript基本知识 JavaScript是一门独立的语言,像我们学习php,python等需要安装apache,python3.6,那我们学习JavaScript只需要我们电脑有一个浏览器即 ...

  7. makefile .phony targets

    Phony Targets PHONY 目标并非实际的文件名:只是在显式请求时执行命令的名字.有两种理由需要使用PHONY 目标:避免和同名文件冲突,改善性能. 如果编写一个规则,并不产生目标文件,则 ...

  8. Spring Data MongoDB 三:基本文档查询(Query、BasicQuery

    一.简介 spring Data  MongoDB提供了org.springframework.data.mongodb.core.MongoTemplate对MongoDB的CRUD的操作,上一篇我 ...

  9. [Z] 关于Python Tornado的一些资料

    一个简单的样例: http://osedu.net/article/python/2014-03-18/501.html ioloop的官方doc: http://www.tornadoweb.org ...

  10. [Z] 将samba共享文件夹映射到linux的目录下

    Linux系统下访问远程共享资源 使用mount加载共享目录: -把WinXP机器192.168.16.249上的共享目录test001映射到本地目录/wdl/下. -把Linux机器192.168. ...