【例1】数星星

天空中有一些星星,这些星星都在不同的位置,每个星星都有个坐标,如果一个星星的左下方(包括正左和正下)有k颗星星,就说这颗星星是k级的。

比如,上图中,星星5是3级的(1,2,4在其左下方)

2,4是1级的。

给定星星的位置,输出各级星星的数目。

简述:先按y坐标来排序,就用x来作为参考用树状数组来求解答案(前缀和)

代码

#include<iostream>
#include<cstdio>
using namespace std;
const int MAXN=;
const int MAXX=;
struct node{
int x,y;
}p[MAXN];
int n,m=MAXX,c[MAXX],ans[MAXX];
int lowbit(int x){
return x&(-x);
}
void update(int x,int y){
while(x<=m)c[x]+=y,x+=lowbit(x);
}
int sum(int x){
int tot=;
while(x){
tot+=c[x];
x-=lowbit(x);
}
return tot;
}
int main(){
cin>>n;
for(int i=;i<=n;++i)cin>>p[i].x>>p[i].y;
for(int i=;i<=n;++i){
int u=p[i].x+;
int v=sum(u);
update(u,);
ans[v]++;
}
for(int i=;i<n;++i)cout<<ans[i]<<endl;
}

【例2】校门外的树2

校门外有很多树,有苹果树,香蕉树,有会扔石头的,有可以吃掉补充体力的……如今学校决定在某个时刻在某一段种上一种树,保证任一时刻不会出现两段相同种类的树,现有两个操作:K=1,K=1,读入l、r表示在区间[l,r]中种上一种树,每次操作种的树的种类都不同K=2,读入l,r表示询问l~r之间能见到多少种树(l,r>0)

简述:这题不能用暴力的方法。所以我们将线段看成括号序列(即左右打上标记,由此就是范围内有一种树),再用前缀和求解。

#include<iostream>
#include<cstdio>
using namespace std;
const int MAXN=;
int n,c_1[MAXN],m,c_2[MAXN];
inline int lowbit(int x){
return x&(-x);
}
void update_1(int x,int y){
for(;x<=n;x+=lowbit(x))c_1[x]+=y;
}
void update_2(int x,int y){
for(;x<=n;x+=lowbit(x))c_2[x]+=y;
}
int sum_1(int x){
int res=;
for(;x;x-=lowbit(x))res+=c_1[x];
return res;
}
int sum_2(int x){
int res=;
for(;x;x-=lowbit(x))res+=c_2[x];
return res;
}
int main(){
cin>>n>>m;
for(int i=;i<=m;++i){
int k,l,r;
cin>>k>>l>>r;
if(k==)update_1(l,),update_2(r,);
else printf("%d\n",sum_1(r)-sum_2(l-));
}
}

【例3】清点人数

初始时,火车上没有学生;当同学们开始上火车时,年级主任从第一节车厢出发走到最后一节车厢,每节车厢随时都有可能有同学上下。年级主任走到第m节车厢时,他想知道第1到m这m节车厢上一共有多少学生,但是他没有调头往回走的习惯.也就是说每次当他提问时,m总会比前一次大。

第一行两个整数n,k,表示火车共有n节车厢以及k个事件。接下来有k行,按时间先后给出k个事件,每行开头都有一个字母A,B或C,如果字母为A,接下来是一个数m,表示年级主任现在在第m节车厢;如果为B,接下来两个数m,p,表示在第m节车厢有p名学生上车;如果为C,接下来两个数m,p,表示在第m节车厢有p名学生下车。学生总人数不会超过100000。

简述:板子题,树状数组求解。

#include<iostream>
#include<cstdio>
using namespace std;
const int MAXN=;
int n,c[MAXN],m;
inline int lowbit(int x){
return x&(-x);
}
void update(int x,int y){
for(;x<=n;x+=lowbit(x))c[x]+=y;
}
int sum(int x){
int res=;
for(;x;x-=lowbit(x))res+=c[x];
return res;
}
int main(){
cin>>n>>m;
for(int i=;i<=m;++i){
int a,b;
char k[];
scanf("%s %d",k,&a);
if(k[]=='A')cout<<sum(a)<<endl;
else if(k[]=='B'){
scanf("%d",&b);
update(a,b);
}
else{
scanf("%d",&b);
update(a,-b);
}
}
}

【例4】简单题easy

有一个n个元素的数组,每个元素初始均为0。有m条指令,要么让其中一段连续序列数字反转——0变1,1变0(操作1),要么询问某个元素的值(操作2)。

第一行包含两个整数n,m,表示数组的长度和指令的条数,以下m行,每行的第一个数t表示操作的种类。若t=1,则接下来有两个数L, R (L<=R),表示区间[L, R]的每个数均反转;若t=2,则接下来只有一个数I,表示询问的下标。

简述:跟校门外的树差不多,都是用双端打标记。这次标记的是区间内修改次数,修改奇数次答案为1,偶数次为0

#include<iostream>
#include<cstdio>
using namespace std;
const int MAXN=;
int n,c_1[MAXN],m,c_2[MAXN];
inline int lowbit(int x){
return x&(-x);
}
void update_1(int x,int y){
for(;x<=n;x+=lowbit(x))c_1[x]+=y;
}
void update_2(int x,int y){
for(;x<=n;x+=lowbit(x))c_2[x]+=y;
}
int sum_1(int x){
int res=;
for(;x;x-=lowbit(x))res+=c_1[x];
return res;
}
int sum_2(int x){
int res=;
for(;x;x-=lowbit(x))res+=c_2[x];
return res;
}
int main(){
cin>>n>>m;
for(int i=;i<=m;++i){
int k,l,r;
cin>>k>>l;
if(k==){
cin>>r;
update_1(l,),update_2(r,);
}
else{
int u=sum_1(l)-sum_2(l-);
printf("%d\n",u%);
}
}
}

树状数组例题-数星星,简单题easy,校门外的树2,清点人数的更多相关文章

  1. 【LeetCode】线段树 segment-tree(共9题)+ 树状数组 binary-indexed-tree(共5题)

    第一部分---线段树:https://leetcode.com/tag/segment-tree/ [218]The Skyline Problem [307]Range Sum Query - Mu ...

  2. 【树状数组】BZOJ3132 上帝造题的七分钟

    3132: 上帝造题的七分钟 Time Limit: 20 Sec  Memory Limit: 128 MBSubmit: 1004  Solved: 445[Submit][Status][Dis ...

  3. hdu 2642二维树状数组 单点更新区间查询 模板题

    二维树状数组 单点更新区间查询 模板 从零开始借鉴http://www.2cto.com/kf/201307/227488.html #include<stdio.h> #include& ...

  4. POJ2155/LNSYOJ113 Matrix【二维树状数组+差分】【做题报告】

    这道题是一个二维树状数组,思路十分神奇,其实还是挺水的 题目描述 给定一个N∗NN∗N的矩阵AA,其中矩阵中的元素只有0或者1,其中A[i,j]A[i,j]表示矩阵的第i行和第j列(1≤i,j≤N)( ...

  5. CF E. Vasya and a Tree】 dfs+树状数组(给你一棵n个节点的树,每个点有一个权值,初始全为0,m次操作,每次三个数(v, d, x)表示只考虑以v为根的子树,将所有与v点距离小于等于d的点权值全部加上x,求所有操作完毕后,所有节点的值)

    题意: 给你一棵n个节点的树,每个点有一个权值,初始全为0,m次操作,每次三个数(v, d, x)表示只考虑以v为根的子树,将所有与v点距离小于等于d的点权值全部加上x,求所有操作完毕后,所有节点的值 ...

  6. luogu P4769 [NOI2018]冒泡排序 结论 树状数组 卡特兰数

    LINK:冒泡排序 神题. 可以想到爆搜 期望得分5~10分. 打成这个样子心态不得爆炸? 仔细分析 一个不合法序列还有什么标志. 容易想到某个数字离自己位置相反的方向多走了一步. 考虑单独对每个数字 ...

  7. BZOJ1227 SDOI2009 虔诚的墓主人【树状数组+组合数】【好题】*

    BZOJ1227 SDOI2009 虔诚的墓主人 Description 小W 是一片新造公墓的管理人.公墓可以看成一块N×M 的矩形,矩形的每个格点,要么种着一棵常青树,要么是一块还没有归属的墓地. ...

  8. POJ - 2464 Brownie Points II 【树状数组 + 离散化】【好题】

    题目链接 http://poj.org/problem?id=2464 题意 在一个二维坐标系上 给出一些点 Stan 先画一条过一点的水平线 Odd 再画一条 过Stan那条水平线上的任一点的垂直线 ...

  9. 二维树状数组(水题) POJ1195

    前段时间遇到线段树过不了,树状数组却过了的题.(其实线段树过得了的) 回忆了下树状数组. 主要原理,还是二进制位数,每一项的和表示其为它的前((最后一位1及其后)的二进制数)和,可从二进制图来看.(用 ...

随机推荐

  1. Tomcat中不能通过访问自己IP,但可以通过localhost/127.0.0.1访问

    一.问题如下:局域网内,自己机器部署了一个tomcat应用,在本机上可以通过如下方式访问引用.  http://localhost:8080/xxxx http://127.0.0.1:8080/xx ...

  2. Linux基础-03-用户、群组

    1. 用户及passwd文件 1) /etc/passwd文件的功能:存储所有用户的相关信息,该文件也被称为用户信息数据库(Database). 2) /etc/passwd文件每个字段的具体含义: ...

  3. Java8新特性 - Java内置的四大核心函数式接口

    Java内置的四大核心函数式接口 Consumer:消费型接口 对类型为T的对象应用操作,包含方法:void accept(T t) public class TestLambda02 { publi ...

  4. ubuntu环境下pycharm编译程序import包出错:ImportError: dynamic module does not define init function (init_caffe)

    出错原因是因为pycharm中的python版本不对,比如程序为2.7版本,但是pycharm编解释器为python3,导致出错,去setting改一下版本就行:pycharm>file> ...

  5. 在Eclipse配置Tomcat服务器+JSP实例创建

    欢迎任何形式的转载,但请务必注明出处. 1.jdk安装及环境配置 点击进入教程 2.Eclipse安装 点击进入官网下载 注意下载完成打开.exe后,出现的界面,有很多版本供选择.选择下图版本 3.T ...

  6. webpack4 + ejs 构建多页应用

    目录结构 ├─build webpack配置目录 │ ├─plugins.js │ ├─rules.js │ ├─transfromAssets.js //简单的一个插件,处理路径问题 │ └─web ...

  7. 使用httpwebrequest发送http请求

    HttpWebRequest request = WebRequest.Create("url") as HttpWebRequest; request.Timeout = * * ...

  8. 记一次渗透某XX站

    0X00 前言 团队A师傅发来个站,问我有没有得搞 正好在搞其他的站,卡住了,开干换个思路. 0x01 信息收集 开burp抓了下包,目标设置了url重写,开了报错,我们随意输入一个控制器就直接报错. ...

  9. python使用Pyinstaller打包

    一.前言 python文件打包,将.py文件转化成.exe文件(windows平台),可以使用Pyinstaller来打包 Pyinstaller可以在全平台下使用,但是请注意打包生成的文件不能在全平 ...

  10. Android NDK 学习之接受Java传入的字符串

    本博客主要是在Ubuntu 下开发,且默认你已经安装了Eclipse,Android SDK, Android NDK, CDT插件. 在Eclipse中添加配置NDK,路径如下Eclipse-> ...