假设每次查询不是整个长度,但[x, y]此时间间隔。

闲来无事写的,感觉是正确的。这将成为合并范围。

#include <cstdio>
#include <cstring>
#include <cmath>
#include <iostream>
#include <queue>
#include <algorithm>
#define mem(f) memset(f,0,sizeof(f))
#define M 100005
#define mod 1000000007
#define lson o<<1, l, m
#define rson o<<1|1, m+1, r
using namespace std;
typedef long long LL;
const int MAX = 0x3f3f3f3f;
const int maxn = 200005; int mx_three(int a, int b, int c) {
return max(a, max(b, c));
} int n, q, c, x, y, b[maxn];
struct C {
int mx, lx, rx;
} a[maxn<<2]; void build(int o, int l, int r) {
a[o].lx = a[o].mx = a[o].rx = 1;
if(l == r) return;
int m = (l+r) >> 1;
build(lson);
build(rson);
} C query(int o, int l, int r) {
if(x <= l && r <= y) return a[o];
int m = (l+r) >> 1, len = r-l+1;
if(y <= m) return query(lson);
if(m < x ) return query(rson); C s, s1, s2;
s1 = query(lson);
s2 = query(rson);
s.lx = s1.lx;
s.rx = s2.rx;
if(b[m] != b[m+1]) {
if(s.lx == len-(len>>1)) s.lx += s2.lx;
if(s.rx == len>>1) s.rx += s1.rx;
s.mx = mx_three(s1.mx, s2.mx, s1.rx+s2.lx);
} else s.mx = max(s1.mx, s2.mx);
return s;
} void update(int o, int l, int r) {
if(l == r) {
b[c] ^= 1;
return;
}
int m = (l+r) >> 1;
if(c <= m) update(lson);
else update(rson); int len = r-l+1, L = o<<1, R = o<<1|1;
a[o].lx = a[L].lx;
a[o].rx = a[R].rx;
if(b[m] != b[m+1]) {
a[o].mx = mx_three(a[L].mx, a[R].mx, a[L].rx+a[R].lx);
if(a[o].lx == len-(len>>1)) a[o].lx += a[R].lx;
if(a[o].rx == len>>1) a[o].rx += a[L].rx;
} else a[o].mx = max(a[L].mx, a[R].mx);
} int main()
{
scanf("%d%d", &n, &q);
build(1, 1, n);
while(q--) {
int rr;
scanf("%d", &rr);
if(rr == 2) {
scanf("%d", &c);
update(1, 1, n);
} else {
scanf("%d%d", &x, &y);
printf("%d\n", query(1, 1, n).mx);
}
}
return 0;
}

Vijos P1881 闪烁的星星 (加强自己多一点。。)的更多相关文章

  1. Vijos P1881 闪烁的星星

    背景 星光闪耀--深蓝色空间 听说过他们的语言 沉默 暮 他们称赞深相互 描写叙述 繁星, 漫天的繁星. 繁星排成一列, 我数一数呀, 一共同拥有N仅仅小星星呢. 星星们是听话的好孩子, 小岛在指挥它 ...

  2. 如何用PowerPoint制作闪烁的星星

    在PPT中,PPT动画说是幻灯片PPT中的精华是当之无愧的!ppt文件有了动画,犹如插上翅膀的鸟,让PPT的色彩衍生出了更多的特色.只要你的ppt动画效果制作的对,你的幻灯片将明显与众不同,观众也更容 ...

  3. canvas画随机闪烁的星星

    canvas画一颗星星: 规则的星星有内切圆和外切圆,每两个点之间的角度是固定的,因此可得到星星的每个点的坐标,画出星星. function drawStars(x,y,radius1,radius2 ...

  4. html5实例-闪烁的星星

    一.绘制五角星 1.1页面结构 <!DOCTYPE html> <html> <head> <meta charset="UTF-8"&g ...

  5. vijos p1881 线段树

    题意:点我 我就想问,现在换代码风格还来得及吗? 2015-05-19:线段树进一步加强,看来不用换风格了 维护左右节点左右端颜色和长度即可 #include<cstdio> #inclu ...

  6. Vijos1881闪烁的繁星 [线段树]

    P1881闪烁的繁星  背景 繁星闪烁着--深蓝的太空何曾听得见他们对语沉默中微光里他们深深的互相颂赞了 描述 繁星, 漫天的繁星.繁星排成一列, 我数一数呀, 一共有N只小星星呢. 星星们是听话的好 ...

  7. HTML5应用——生日快乐动画之星星

    在讲述绘制星星动画之前,先介绍一点javascript知识. 面向对象: javascript本质上不是面向对象语言,而是脚本语言,一般只适合简单.代码量少的程序,因为脚本过于复杂会直接导致浏览器出现 ...

  8. css3中变形与动画(三)

    transform可以实现矩阵变换,transition实现属性的平滑过渡,animation意思是动画,动漫,这个属性才和真正意义的一帧一帧的动画相关.本文就介绍animation属性. anima ...

  9. 荒木毬菜 小情歌日文版 - 独身OL之歌

    咎(とが)めるつもりもないけどtogameru tumorimo naikedo并不想责备在身旁 暇(ひま)してる时间(じかん)をhimashiteru jikan wo无所事事的时间 パジャマの鸟( ...

随机推荐

  1. kiss框架学习

    #parse("$!jc.skinpath/exam/cart.ascx") var CategoryId = "$!this.loadCategory_combo(). ...

  2. Android---OpenGL ES之添加动作

    本文译自:http://developer.android.com/training/graphics/opengl/motion.html 在屏幕上绘制对象是OpenGL的最基本功能,你可以使用其他 ...

  3. OCA读书笔记(9) - 管理数据同步

    9.Managing Data Concurrency 描述锁机制以及oracle如何管理数据一致性监控和解决锁冲突 管理数据的并发--管理锁数据的不一致:脏读更改丢失幻影读 脏读:数据是指事务T2修 ...

  4. H264 Decoder

    http://www.cnblogs.com/mcodec/category/213433.html

  5. Echart饼图、柱状图、折线图(pie、bar、line)加入点击事件

    var myChart= echarts.init(document.getElementById('myChart')); myChart.on('click', function (param) ...

  6. ubuntu12.04安装深度音乐播放器和深度影音

    昨天折腾了一天,想要安装深度播放器和深度影音都未成功,老是出现依赖关系不满足这个错误.网上解决办法有非常多,可是都没能有效的解决这个问题.今天突然想起来之前换过软件源,是不是这个原因而导致了依赖关系不 ...

  7. VSTO之旅系列(一):VSTO入门

    原文:VSTO之旅系列(一):VSTO入门 引言: 因为工作的原因,这段时间一直在看VSTO的相关的内容的,因此希望通过这个系列来记录下我学习的过程和大家分享Office开发的相关知识,希望以后有朋友 ...

  8. hdu2159(二维完全背包)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2159 题意:打怪,还有最后一级,忍耐度有限m,问在杀怪数量上限为s的情况下能否获取n经验而通关,且忍耐 ...

  9. c# winform 子窗体访问父窗体中的方法和变量

    今天的工作中突然用到这个了,不过以前没有接触过呢!不过,在有经验的同事的帮助下,这个问题也很快解决了.具体可以分为以下几种方式: 1.在父窗体中构造子窗体对象时,将父窗体传递过去: 如:FrmSub ...

  10. Inno Setup打包添加和去除管理员权限

    原文:Inno Setup打包添加和去除管理员权限 添加管理员权限 1.在[Setup]节点添加 PrivilegesRequired=admin 2.进入安装目录,找到文件SetupLdr.e32, ...