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的右端点数目) - (> ...
随机推荐
- Linux 用户行为日志记录
工作中我们常常遇到,有的员工不安于被分配的权限,老是想sudo echo "ziji" /usr/bin/visudo NOPASSWD:ALL来进行提权,造成误删了数据库某条重要 ...
- Android Kotlin适用小函数
都是一些Android适用的Kotlin小函数. 1.点击空白隐藏键盘 //点击空白隐藏键盘 override fun onTouchEvent(event: MotionEvent): Boolea ...
- 转投emacs
(global-set-key [f9] 'compile-file) (global-set-key [f10] 'gud-gdb) (global-set-key (kbd "C-z&q ...
- mof格式的文件怎么打开?用什么工具?
托管对象格式 (MOF) 文件是创建和注册提供程序.事件类别和事件的简便方法.在 MOF 文件中创建类实例和类定义后,可以对该文件进行编译.有关更多信息,请参见编译托管对象格式 (MOF) 文件.编译 ...
- 设计模式之第10章-桥接模式(Java实现)
设计模式之第10章-桥接模式(Java实现) “一入软件深似海,从此早睡是路人.黑夜给了我黑色的眼睛,我却用他去寻找八阿哥.”“怎么了,又来那么多的感慨啊.”“还能有什么啊,老板是说让换个APP做,这 ...
- Android onConfigurationChanged用法(规避横竖屏切换导致的重新调用onCreate方法)
onConfigurationChanged的目的是为了规避横竖屏切换干掉activity而重新调用onCreate方法的问题:有的时候,我们希望重新进入OnCreate生命周期,此时可以调用onSa ...
- PHP 命名空间和自动加载
PHP 命名空间 php5.3 之后引入了命名空间的特性,从本质上讲,命名空间就是一个容器,你可以将类.函数和变量放在其中,在命名空间中,你可以无条件地访问这些项,在命名空间之外,必须导入或引用命名空 ...
- JVM虚拟机系列(三)Class文件格式
- IE IE8 iframe的onload方法分析 IE浏览器onload事件失效
判断iframe是否加载完成的完美方法 IE 支持 iframe 的 onload 事件,不过是隐形的,需要通过 attachEvent 来注册. 第二种方法比第一种方法更完美(采用readystat ...
- Incorrect column count: expected 1, actual 6
JdbcTemplate使用时出现了一些问题: 解决办法: