---恢复内容开始---

http://poj.org/problem?id=2352

这是一个树状数组的题目,也是我第一次接触这类的题目,也正是因为之前的一道题,TLE了,超时太严重了,我看discuss里再说什么用树状数组可以我才去找有关于这方面的博客看

看了很多博客才稍微的理解了一点树状数组,可以在以后的做题中,加强对这个的理解

这个图片就是数组数组的内涵所在

其中A数组就是原数组,而C[n]=a[n-2^k+1]+.......+a[n]的值,其中K为二进制下的末尾0的个数,比如c[8],8(1000)有3个0,所以,k=3,则C[8]就表示从a[1]到a[8]的值;

int lowbit(int x)

{

  return x&(-x);    //这个就是用来返回2^k的值的。

}

而对于查询来说的话

求(1,8)的值就是为C[8]

而求(4,8)的值时则可以用C[8]-c[3]-c[2];

也就是sum(a,b)=sum(1,b)-sum(1,a-1);

 int sum(int end)           //计算原数组1-end的和
{
int sum=;
while(end>)
{
sum+=c[end];
end-=lowbit(end);
}
return sum;
}

关于上面的第6-7行,我觉得举两个实例更加容易理解

比如说要求1-8的和也就是c[8];

首先end=8;

也就是sum=c[8];

而lowbit=8,所以,sum=c[8];

而当end=7;时

首先sum=c[7];

而7(111)所以C[7]=a[7];

lowbit(7)=1;

所以接下来就是sum=c[7]+c[6];

6(110)所以,c[6]=a[5]+a[6];

end=4;

在接下来就是sum=c[7]+c[6]+c[4];

4(100)所以,c[4]=a[1]+....+a[4];

end=0;

不得不说,这个确实很巧妙

对于更新的话,这个只有一个点一个点的进行更新

下面为从a[pos]的位置上加一个num:

 void update(int pow,int num)
{
while (pow<=n)
{
c[pow]+=num;
pow+=lowbit(pow);
}
}

其实有了上面的的举例之后,也可以感觉得到在某个位置上加个数之后,只不过是在被C包围的那个位置上加上个数,所对应的C也自然而然的加,

且这个有局限性就是只可以对于单个节点进行更新

对于二维数组数组

下面的代码给a[i][j]这一节点加上个K

 void update(int i,int j,int k)
{
while (i<=n)
{
int temp=j;
while(temp<=n)
{
c[i][temp]+=k;
temp+=lowbit(temp);
}
i+=lowbit(i);
}
}

下面就是关于POJ2352的一个解题代码

 #include <stdio.h>
#include <iostream> using namespace std; int n;
int level[]; //level就是用来存等级的
int c[];        //树状数组
int lowbit(int x)
{
return x&(-x);
} int sum(int x) //求和
{
int s=;
while(x>)
{
s+=c[x];
x-=lowbit(x);
}
return s;
} void update(int pos) //更新,因为树状数组么,所以它肯定是更新到最顶端!
{
while(pos<=)
{
c[pos]++;
pos+=lowbit(pos);
}
}
int main()
{
scanf("%d",&n);
int x,y;
for(int i=;i<=n;i++)
{
scanf("%d%d",&x,&y);
level[sum(x+)]++; //每次多一个之后,sum(x+1)所对应的那个等级就会++,而为什么是X+1的目的就是避免X=0,而且不会影响其的相对位置,如果不理解,多看几遍就会懂其内涵
update(x+);
}
for(int i=;i<n;i++)
{
printf("%d\n",level[i]);
}
return ;
}

POJ 2352的更多相关文章

  1. poj 2352 Stars 数星星 详解

    题目: poj 2352 Stars 数星星 题意:已知n个星星的坐标.每个星星都有一个等级,数值等于坐标系内纵坐标和横坐标皆不大于它的星星的个数.星星的坐标按照纵坐标从小到大的顺序给出,纵坐标相同时 ...

  2. POJ 2352 Stars(线段树)

    题目地址:id=2352">POJ 2352 今天的周赛被虐了. . TAT..线段树太渣了..得好好补补了(尽管是从昨天才開始学的..不能算补...) 这题还是非常easy的..维护 ...

  3. POJ 2352 Stars(树状数组)

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

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

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

  5. 【树状数组】POJ 2352 Stars

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

  6. POJ 2352 star level

    题目链接: http://poj.org/problem?id=2352 题目大意:对于每一颗星星来说,都有一个属于自己的level,这个值为其他星星x,y坐标均不大于本星星的个数.输入时按先y由小到 ...

  7. 【POJ 2352】 Stars

    [题目链接] http://poj.org/problem?id=2352 [算法] 树状数组 注意x坐标为0的情况 [代码] #include <algorithm> #include ...

  8. POJ 2352 Stars 线段树

    题目链接 题意:在一个二维平面上有n个星星,每个星星的等级为x,x为该星星左方和下方所包含的星星的数量(包含正左和正下的),输出每个等级各有多少星星,星星坐标按照y序递增给出,y值相同按照x递增给出. ...

  9. POJ 2352 Stars 线段树 数星星

    转载自 http://www.cnblogs.com/fenshen371/archive/2013/07/25/3214927.html 题意:已知n个星星的坐标.每个星星都有一个等级,数值等于坐标 ...

随机推荐

  1. Last-Modify和Etag

    Last-Modified和Etag Last-Modified是页面文件最后的修改时间,Etag相当于页面文件的hash. http request          http respose If ...

  2. Spring4学习笔记-AOP

    1.加入jar包 com.springsource.org.aopalliance-1.0.0.jar com.springsource.org.aspectj.weaver-1.6.8.RELEAS ...

  3. commons-pool实战之 GenericObjectPool和GenericKeyedObjectPool

    前面两篇文章说了怎么样简单的使用commons-pool库,这里需要考虑一个问题就是在很多时候我们在池里的对象都是比较重型的并且大多数比较稀缺的 资源,比如说数据库连接,这样如果一直把一些连接放在池里 ...

  4. 获取Executor提交的并发执行的任务返回结果的两种方式/ExecutorCompletionService使用

    当我们通过Executor提交一组并发执行的任务,并且希望在每一个任务完成后能立即得到结果,有两种方式可以采取: 方式一: 通过一个list来保存一组future,然后在循环中轮训这组future,直 ...

  5. twoSum

    Given an array of integers, find two numbers such that they add up to a specific target number. The ...

  6. wtforms 使用

    wtforms是一个表单模板库, 下面以修改密码表单为例简单说明其用法. 我们可以用python代码定义form的基本元素, 比如用户名/邮箱, 并给定各个元素的validation条件. 然后在re ...

  7. PHP中的Memcache详解

    一.Memcache简介 Memcache是danga.com的一个项目,最早是为 LiveJournal 服务的,目前全世界不少人使用这个缓存项目来构建自己大负载的网站,来分担数据库的压力.它可以应 ...

  8. 解析posix与perl标准的正则表达式区别 ---PHP

        正则表达式(Regular Expression,缩写为regexp,regex或regxp),又称正规表达式.正规表示式或常规表达式或正规化表示法或正规表示法,是指一个用 来描述或者匹配一系 ...

  9. [译]Create a Web API in MVC 6

    原文: http://www.asp.net/vnext/overview/aspnet-vnext/create-a-web-api-with-mvc-6 ASP.NET 5.0的一个目标是合并MV ...

  10. 【Junit】JUnit-4.12使用报java.lang.NoClassDefFoundError: org/hamcrest/SelfDescribing错误

    下载了最新的JUnit版本,是4.12,结果尝试使用发现总是报java.lang.NoClassDefFoundError: org/hamcrest/SelfDescribing这样的错误, 上网查 ...