题目地址: 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. Hibernate学习7—Hibernate 映射继承

    需求:学生有很多照片,分为生活照和工作照: 第一节:每个具体类对应一个表 Student.java: package com.cy.model; import java.util.Set; publi ...

  2. spring扩展点之一:BeanFactoryPostProcessor和BeanPostProcessor

    一.BeanFactoryPostProcessor和BeanPostProcessor的区别 BeanFactoryPostProcessor和BeanPostProcessor都是spring初始 ...

  3. python文本挖掘模版

    import xlrd import jieba import sys import importlib import os #python内置的包,用于进行文件目录操作,我们将会用到os.listd ...

  4. 不能调用jquery中ready里面定义的函数?

    现象:不能调用jquery中ready里面定义的函数 源码:<script type="text/javascript"> $(document).ready(func ...

  5. Java垃圾回收机制和内存分配

    收集算法是内存回收的方法论,垃圾收集器是内存回收的具体实现 自动内存管理解决的是:给对象分配内存 以及 回收分配给对象的内存 为什么我们要了解学习 GC 与内存分配呢? 在 JVM 自动内存管理机制的 ...

  6. UVA-11292Dragon of Loowater

    /* The Dragon of Loowater Once upon a time, in the Kingdom of Loowater, a minor nuisance turned into ...

  7. Php函数set_include_path()函数详解

    set_include_path--设置include_path配置选项. 说明 string set_include_path(string $new_include_path); 为当前脚本设置i ...

  8. 太白老师day6 1.代码块 2.is==id 3.小数据池

    1.代码块: 一个模块一个函数一个类,一个文件都是代码块 在交互模式下, 每一行都是一个代码块 2. is == 内存地址 就是id门牌号 在内存中id是唯一,如果两个变量指向的id相同,那么他们在内 ...

  9. 禁止xfce4黑屏

    我在ubuntu server上安装了xfce,可是每隔十分钟电脑就会黑屏.安装了xfce自带的电源管理程序.貌似不起作用.后来从网上找到如下方法: 修改/etc/X11/xorg.conf配置文件, ...

  10. mongodb 的操作

    查找 db.collection的名字.find({"group":"kkkk","key":{$regex:/.*one.*/i}}); ...