Code[VS]1690 开关灯 题解
#include "bits/stdc++.h" #define maxN 100010 using namespace std;
typedef long long QAQ; struct Tree
{
int l, r ;
QAQ sum ;//当前开着的灯数量
bool idv;//开关灯的延迟标记
}; QAQ Min(QAQ a, QAQ b)
{
return a > b ? b : a;
} Tree tr[maxN << ]; void Push_down ( int i , int m)
{
if(tr[i].idv)//当前结点有延迟标记
{
tr[i << ].idv = !tr[i << ].idv ;//左
tr[i << | ].idv = !tr[i << | ].idv ;//右
tr[i << ].sum = tr[i << ].r - tr[i << ].l + - tr[i << ].sum ;//所以灯开关状态取反
tr[i << | ].sum = tr[i << | ].r - tr[i << | ].l + - tr[i << | ].sum ;//同上
tr[i].idv = !tr[i].idv ;//清零!!!
}
} void Build_Tree (int x , int y, int i)
{
tr[i].l = x ;//左端点
tr[i].r = y ;//右端点
if( x == y)return ;
else
{
QAQ mid = (tr[i].l + tr[i].r ) >> ;
Build_Tree ( x , mid , i << );//左递归
Build_Tree (mid + , y , i << | );//右递归
}
} void Update_Tree (int q , int w , int i)
{
if( w >= tr[i].r && q <= tr[i].l)//被完全包含
{
tr[i].idv = !tr[i].idv;//延迟标记
QAQ tot = tr[i].r - tr[i].l + ;//当前结点总共的灯
tr[i].sum = tot - tr[i].sum;//开关状态全部取反
return ;
}
else
{
Push_down( i , tr[i].r - tr[i].l + );//信息下传函数
QAQ mid = (tr[i].l + tr[i].r) >> ;
if( q > mid )
{
Update_Tree ( q , w , i << | );
}
else if ( w <= mid )
{
Update_Tree ( q , w , i << );
}
else
{
Update_Tree ( q , w , i << | );
Update_Tree ( q , w , i << );
}
tr[i].sum = tr[i << ].sum + tr[i << | ].sum ;//回溯更新
}
} QAQ Query_Tree (int q , int w , int i )
{
if( w >= tr[i].r && q <= tr[i].l)
{
return tr[i].sum;//被完全包含直接返回值
}
else
{
Push_down( i , tr[i].r - tr[i].l + );
QAQ mid = (tr[i].l + tr[i].r ) >> ;
if( q > mid )
{
return Query_Tree ( q , w , i << | );
}
else if ( w <= mid )
{
return Query_Tree ( q , w , i << );
}
else
{
return Query_Tree ( q , w , i << | ) + Query_Tree ( q , w , i << );
}
}
} int main ( )
{
QAQ N, M;
int op, l, r;
scanf("%d%d", &N, &M);
Build_Tree ( , N , );//建树操作
while (M--)
{
scanf("%d", &op);
if( !op )
{
scanf("%d%d", &l, &r);
Update_Tree ( l , r , );//更新树
}
else
{
scanf("%d%d", &l, &r);
printf("%lld\n", Query_Tree ( l , r , ));//查询
}
}
return ;
}
Code[VS]1690 开关灯 题解的更多相关文章
- codevs——1690 开关灯
1690 开关灯 USACO 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题解 题目描述 Description YYX家门前的街上有N( ...
- Code[VS] 1022 覆盖 题解
Code[VS] 1022 覆盖 题解 Hungary Algorithm 题目传送门:Code[VS] 1022 题目描述 Description 有一个N×M的单位方格中,其中有些方格是水塘,其 ...
- Code[VS] 2152 滑雪题解
Code[VS] 2152 滑雪题解 题目描述 Description trs喜欢滑雪.他来到了一个滑雪场,这个滑雪场是一个矩形,为了简便,我们用r行c列的矩阵来表示每块地形.为了得到更快的速度,滑行 ...
- Codevs 1690 开关灯 USACO
1690 开关灯 USACO 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 传送门 题目描述 Description YYX家门前的街上有N(2<=N& ...
- 线段树——codevs 1690 开关灯
先来一发题目: 1690 开关灯 时间限制: 1 s 空间限制: 128000 KB 题目描述 Description YYX家门前的街上有N(2<=N<=100000)盏路灯,在晚上六点 ...
- codevs 1690 开关灯 线段树+延迟标记
1690 开关灯 时间限制: 1 s 空间限制: 128000 KB 题目描述 Description YYX家门前的街上有N(2<=N<=100000)盏路灯,在晚上六点之前,这 ...
- 线段树--codevs 1690 开关灯
codevs 1690 开关灯 USACO 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description YYX家门前的街上有N(2& ...
- Code[VS] 2370 LCA 题解
Code[VS] 2370 小机房的树 题解 RMQ 树链剖分 题目描述 Description 小机房有棵焕狗种的树,树上有N个节点,节点标号为0到N-1,有两只虫子名叫飘狗和大吉狗,分居在两个不同 ...
- 【wikioi】1690 开关灯(线段树)
http://wikioi.com/problem/1690/ 这题可不能算是水题了.. 在线段树中,我只想到了lazy改变,但是没想到lazy变后size怎么变,我的策略变成了lazy为0时size ...
随机推荐
- HTTPS的一些疑问解答
PHP写的网站怎么用https访问,具体要怎样 这跟用什么语言写的网站没有关系,可以去申请个快速的SSL证书,一年也就几十块. 开启apache server的ssl,自己做个免费的ssl证书或者去申 ...
- Delphi中函数定义和声明的位置
当函数(或过程)A定义在函数(或过程)B之前,那么函数B就可以调用函数A,并且编译成功,例如下面的 procedure TForm1.btn1Click(Sender: TObject); 和 f ...
- 【openGL】画正弦函数图像
#include "stdafx.h" #include <GL/glut.h> #include <stdlib.h> #include <math ...
- org.hibernate.HibernateException: A collection with cascade="all-delete-orphan" was no longer referenced by the owning entity instance:
详细错误堆栈信息: org.hibernate.HibernateException: A collection with cascade="all-delete-orphan" ...
- Oracle 数据泵文件
数据泵文件 expdp介绍 EXPDP命令行选项1. ATTACH该选项用于在客户会话与已存在导出作用之间建立关联.语法如下ATTACH=[schema_name.]job_nameSchema_na ...
- 利用IdentityServer3在ASP.NET 5和Angular中实现OAuth2 Implicit Flow
(此文章同时发表在本人微信公众号"dotNET每日精华文章",欢迎右边二维码来关注.) 题记:之前介绍过的IdentityServer3虽然是基于Katana开发的,不过同样可以托 ...
- 把VSO作为GitHub上JavaScript项目的免费CI服务器
(此文章同时发表在本人微信公众号"dotNET每日精华文章",欢迎右边二维码来关注.) 题记:微软变得更加开放后,走向开放的不仅有.NET运行时.IDE工具,还有ALM服务器核心组 ...
- C++中引用(&)的用法和应用实例
转自:http://www.cnblogs.com/Mr-xu/archive/2012/08/07/2626973.html 对于习惯使用C进行开发的朋友们,在看到c++中出现的&符号,可能 ...
- 网页或php服务连不上的几个可能原因
1.webserver未启动. 2.php未启动. 3.url中端口和webserver配置文件中的不一致.
- JSHint配置详解
Also available on Github JSHint配置详解 增强参数(Enforcing Options) 本类参数设为true,JSHint会产生更多告警. bitwise 禁用位运算符 ...