cogs——1008. 贪婪大陆(清华巨佬代码)——树状数组
1008. 贪婪大陆
★★ 输入文件:greedisland.in 输出文件:greedisland.out 简单对比
时间限制:1 s 内存限制:128 MB
- 试题四:贪婪大陆
- 【题目描述】
- 面对蚂蚁们的疯狂进攻,小FF的Tower defense宣告失败……人类被蚂蚁们逼到了Greed Island上的一个海湾。现在,小FF的后方是一望无际的大海,前方是变异了的超级蚂蚁。 小FF还有大好前程,他可不想命丧于此, 于是他派遣手下最后一批改造SCV布置地雷以阻挡蚂蚁们的进攻。
- 小FF最后一道防线是一条长度为N的战壕, 小FF拥有无数多种地雷,而SCV每次可以在[ L , R ]区间埋放同一种不同于之前已经埋放的地雷。 由于情况已经十万火急,小FF在某些时候可能会询问你在[ L' , R'] 区间内有多少种不同的地雷, 他希望你能尽快的给予答复。
- 【输入格式】
- 第一行为两个整数n和m; n表示防线长度, m表示SCV布雷次数及小FF询问的次数总和。
- 接下来有m行, 每行三个整数Q,L , R; 若Q=1 则表示SCV在[ L , R ]这段区间布上一种地雷, 若Q=2则表示小FF询问当前[ L , R ]区间总共有多少种地雷。
- 【输出格式】
- 对于小FF的每次询问,输出一个答案(单独一行),表示当前区间地雷总数。
- 【输入样例】
- 5 4
- 1 1 3
- 2 2 5
- 1 2 4
- 2 3 5
- 【输出样例】
- 1
- 2
- 【数据范围】
- 对于30%的数据: 0<=n, m<=1000;
- 对于100%的数据: 0<=n, m<=10^5.
- 代码:
- one
#include<cstdio>
);
int n,m,tot;
][];
,){
if(left==right){
t[p][k]++;
return;
}
;
);
,right,p<<|);
t[p][]=t[p<<][]+t[p<<|][];
t[p][]=t[p<<][]+t[p<<|][];
}
,){
if(x<=left&&right<=y)
return t[p][k];
,ans=;
);
,right,p<<|);
return ans;
}
int main(){
freopen("greedisland.in","r",stdin);
freopen("greedisland.out","w",stdout);
scanf("%d%d",&n,&m);
;q<=m;q++){
int ty,x,y;
scanf("%d%d%d",&ty,&x,&y);
){
insert(x,);
insert(y,);
tot++;
}
else
printf(,x-,)-query(y+,n,));
}
;
}
two
#include<cstdio>
);
int n,m,tot;
],tag[MAXN<<],mark[MAXN<<];
void increase(int p,int k){
t[p]+=k;
tag[p]+=k;
mark[p]+=k;
}
void push_down(int p){
int& d=tag[p];
increase(p<<,d);
increase(p<<|,d);
d=;
}
,){
if(x<=left&&right<=y){
increase(p,);
return;
}
push_down(p);
;
);
,right,p<<|);
t[p]++;
if(x<=mid&&y>mid)mark[p]++;
}
,){
if(x<=left&&right<=y)
return t[p];
push_down(p);
,ans=;
);
,right,p<<|);
if(x<=mid&&y>mid)ans-=mark[p];
return ans;
}
int main(){
freopen("greedisland.in","r",stdin);
freopen("greedisland.out","w",stdout);
scanf("%d%d",&n,&m);
;q<=m;q++){
int ty,x,y;
scanf("%d%d%d",&ty,&x,&y);
)
insert(x,y);
else
printf("%d\n",query(x,y));
}
;
}
cogs——1008. 贪婪大陆(清华巨佬代码)——树状数组的更多相关文章
- Cogs 1008. 贪婪大陆(树状数组)
贪婪大陆 难度等级 ★★ 时间限制 1000 ms (1 s) 内存限制 128 MB 测试数据 10 简单对比 输入文件:greedisland.in 输出文件:greedisland.out 简单 ...
- cogs 1008 贪婪大陆
/* 不要思维定视 盯着线段树维护l r 的ans不放 显然没法区间合并 换一种思路 如果打暴力的话 O(nm) 每次询问 扫一遍之前所有的修改 有交点则说明种数++ 接下来考虑如何优化 我们把每个区 ...
- COGS1008. 贪婪大陆[树状数组 模型转换]
1008. 贪婪大陆 ★★ 输入文件:greedisland.in 输出文件:greedisland.out 简单对比时间限制:1 s 内存限制:128 MB 试题四:贪婪大陆 [题 ...
- luoguP2184 贪婪大陆 题解(树状数组)
P2184 贪婪大陆 题目 其实很容易理解就是询问一段区间内有多少段不同的区间 然后再仔细思索一下会发现: 1.只要一个区间的开头在一个节点i的左边,那么这个区间包含在区间1~i中. 2.只要一个区 ...
- [luoguP2184] 贪婪大陆(树状数组)
传送门 用两个树状数组,cr 维护 1....x 中 r 的数量 cl 维护 1....x 中 l 的数量 求答案的时候只需要求 y 前面 被作为左端点 的个数 - x 前面 被作为右端点的个数 —— ...
- COGS.1822.[AHOI2013]作业(莫队 树状数组/分块)
题目链接: COGS.BZOJ3236 Upd: 树状数组实现的是单点加 区间求和,采用值域分块可以\(O(1)\)修改\(O(sqrt(n))\)查询.同BZOJ3809. 莫队为\(O(n^{1. ...
- [清华集训2017]小 Y 和地铁(神奇思路,搜索,剪枝,树状数组)
世界上最不缺的就是好题. 首先考虑暴搜.(还有什么题是从这东西推到正解的……) 首先单独一个换乘站明显没用,只用考虑一对对的换乘站. 那么有八种情况:(从题解偷图) 然后大力枚举每个换 ...
- [luogu P2184] 贪婪大陆 [树状数组][线段树]
题目背景 面对蚂蚁们的疯狂进攻,小FF的Tower defence宣告失败……人类被蚂蚁们逼到了Greed Island上的一个海湾.现在,小FF的后方是一望无际的大海, 前方是变异了的超级蚂蚁. 小 ...
- P2184 贪婪大陆 树状数组
树状数组帅炸了....又被一道水题轻虐,又被学长指出了一个错误....我太菜了QAQ 开两个树状数组,一个记录左端点,一个记录右端点: 共有cnt(总数) - (<l的右端点数目) - (> ...
随机推荐
- callback回调函数【转】
请给作者点赞--> 原文链接 什么是回调函数? 我们绕点远路来回答这个问题. 编程分为两类:系统编程(system programming)和应用编程(application programmi ...
- Appium运行时没有启动activity的权限:A new session could not be created.(Original error: Permission to start activity denied)
小白搞appium,遇到启动不了activity的问题: 查找解决方案说是跟AndroidManifest.xml有关系,参考:https://github.com/appium/appium/iss ...
- TCP/IP网络编程之基于TCP的服务端/客户端(二)
回声客户端问题 上一章TCP/IP网络编程之基于TCP的服务端/客户端(一)中,我们解释了回声客户端所存在的问题,那么单单是客户端的问题,服务端没有任何问题?是的,服务端没有问题,现在先让我们回顾下服 ...
- Storm Ack容错机制
- wordpress 区分多语言站点
$blog_title = get_bloginfo( 'name' ); $table_name = ''; if ( $blog_title == 'Driver Easy' ) { $table ...
- vim中插入递增数
假设生成0-9的递增数 1.插入数字1,yy复制,9p 2.输入命令 let i= | g//s//\=i/ | let i=i+1 3.结果:
- Java学习6之泛型
1.泛型定义 1.泛型类: public class Generic <T>{ public void get(T t){ System.out.println(t); } } examp ...
- 二维数组的动态分配(new)、初始化(memset)和撤销(delete)
来自http://blog.csdn.net/maverick1990/article/details/22829135 一维数组 动态分配,int *array = new int[10] 初始化, ...
- DNS(转载)
最近帮朋友注册域名配置主机,碰到一些DNS上的一些概念,惭愧于有一些东西已经忘记是啥意思,于是决定重新学习一下DNS方面的基本概念. 常用概念: TTL: TTL为Time to live的缩写,网络 ...
- cookie和session机制区别
会话(Session)跟踪是Web程序中常用的技术,用来跟踪用户的整个会话.常用的会话跟踪技术是Cookie与Session.Cookie通过在客户端记录信息确定用户身份,Session通过在服务器端 ...