Loj 【CQOI 2006】简单题,mmp
题目描述
题目来源:CQOI 2006
有一个 nnn 个元素的数组,每个元素初始均为 000。有 mmm 条指令,要么让其中一段连续序列数字反转——000 变 111,111 变 000(操作 111),要么询问某个元素的值(操作 222)。
例如当 n=20n=20n=20 时,101010 条指令如下:
操作 | 回答 | 操作后的数组 |
---|---|---|
1 1 101\ 1\ 101 1 10 | N/A | 111111111100000000001111111111000000000011111111110000000000 |
2 62\ 62 6 | 111 | 111111‾1111000000000011111\underline{1}1111000000000011111111110000000000 |
2 122\ 122 12 | 000 | 111111111100‾0000000011111111110\underline{0}0000000011111111110000000000 |
1 5 121\ 5\ 121 5 12 | N/A | 111100000011000000001111000000110000000011110000001100000000 |
2 62\ 62 6 | 000 | 111100‾0000110000000011110\underline{0}0000110000000011110000001100000000 |
2 152\ 152 15 | 000 | 111100000011000‾0000011110000001100\underline 00000011110000001100000000 |
1 6 161\ 6\ 161 6 16 | N/A | 11110111110011110000 1111011111001111000011110111110011110000 |
1 11 171\ 11\ 171 11 17 | N/A | 111101111111000010001111011111110000100011110111111100001000 |
2 122\ 122 12 | 111 | 111101111111‾0000100011110111111\underline 10000100011110111111100001000 |
2 62\ 62 6 | 111 | 111101‾1111110000100011110\underline 11111110000100011110111111100001000 |
输入格式
第一行包含两个整数 n,mn,mn,m,表示数组的长度和指令的条数;
以下 mmm 行,每行的第一个数 ttt 表示操作的种类:
- 若 t=1t=1t=1,则接下来有两个数 L,RL, RL,R,表示区间 [L,R][L, R][L,R] 的每个数均反转;
- 若 t=2t=2t=2,则接下来只有一个数 iii,表示询问的下标。
输出格式
每个操作 222 输出一行(非 000 即 111),表示每次操作 222 的回答。
样例
样例输入
20 10
1 1 10
2 6
2 12
1 5 12
2 6
2 15
1 6 16
1 11 17
2 12
2 6
样例输出
1
0
0
0
1
1
数据范围与提示
对于 50%50\%50% 的数据,1≤n≤103,1≤m≤1041\le n\le 10^3,1\le m\le 10^41≤n≤103,1≤m≤104;
对于 100%100\%100% 的数据,1≤n≤105,1≤m≤5×1051\le n\le 10^5,1\le m\le 5\times 10^51≤n≤105,1≤m≤5×105,保证 L≤RL\le RL≤R。
分析
其实这道题很简单(只要你想得到的话)
首先区间操作,区间查询,很容易想到 RMQ ,然后树状数组和线段树貌似没有翻转区间信息的功能啊。怎么办呢?
那么我们考虑一下这道题的性质:最后得到的数字只可能是 0 或 1 也就是说如果某个位置被翻转两遍那么效果是一样的。。。
然后要非常生硬的联想到位运算 & ...
接下来我们这么操作(鉴于树状数组常数小那么就用树状数组的讲法了,至于线段树也就是永久化标记的事儿):
我们每次直接去加一个区间的左端点 l 以及右端点 r+1 ,那么 r+1 以及后面位置上的数被翻转了两次,最低位还是不变
查询的时候我们直接单点查询(这里不需要什么骚操作,直接查询 x 的前缀和就好了,因为前面区间没有覆盖到 x 的话必然是向后累加了两次的,效果会抵消)。
没错,很朴素。没错,很简单。没错,就是想不到。
代码
Loj 【CQOI 2006】简单题,mmp的更多相关文章
- CQOI 2006 简单题
CQOI 2006 简单题 有一个 n 个元素的数组,每个元素初始均为 0.有 m 条指令,要么让其中一段连续序列数字反转--0 变 1,1 变 0(操作 11),要么询问某个元素的值(操作 2). ...
- loj 10117 简单题(cqoi 2006)
题目来源:CQOI 2006 有一个 n 个元素的数组,每个元素初始均为 0.有 m条指令,要么让其中一段连续序列数字反转——0变 1,1 变 0(操作 1),要么询问某个元素的值(操作 2). 例如 ...
- LOJ#10117. 「一本通 4.1 练习 2」简单题
LOJ#10117. 「一本通 4.1 练习 2」简单题 题目描述 题目来源:$CQOI 2006$ 有一个$n$个元素的数组,每个元素初始均为$0$.有$m$条指令,要么让其中一段连续序列数字反转— ...
- unctf2020 部分简单题题解
unctf2020 水一波简单题..菜狗前来报道..大佬轻喷..如果有时间做题就好了呜呜呜 misc 1.baba_is_you 题目告诉我们,了解png文件格式. 下载得到一张png格式的图片. 用 ...
- BZOJ 2683: 简单题
2683: 简单题 Time Limit: 50 Sec Memory Limit: 128 MBSubmit: 913 Solved: 379[Submit][Status][Discuss] ...
- 【BZOJ-1176&2683】Mokia&简单题 CDQ分治
1176: [Balkan2007]Mokia Time Limit: 30 Sec Memory Limit: 162 MBSubmit: 1854 Solved: 821[Submit][St ...
- Bzoj4066 简单题
Time Limit: 50 Sec Memory Limit: 20 MBSubmit: 2185 Solved: 581 Description 你有一个N*N的棋盘,每个格子内有一个整数,初 ...
- Bzoj2683 简单题
Time Limit: 50 Sec Memory Limit: 128 MBSubmit: 1071 Solved: 428 Description 你有一个N*N的棋盘,每个格子内有一个整数, ...
- 这样leetcode简单题都更完了
这样leetcode简单题都更完了,作为水题王的我开始要更新leetcode中等题和难题了,有些挖了很久的坑也将在在这个阶段一一揭晓,接下来的算法性更强,我就要开始分专题更新题目,而不是再以我的A题顺 ...
随机推荐
- Hadoop记录-yarn ResourceManager Active频繁易主问题排查(转载)
一.故障现象 两个节点的ResourceManger频繁在active和standby角色中切换.不断有active易主的告警发出 许多任务的状态没能成功更新,导致一些任务状态卡在NEW_SAVING ...
- C#设计模式(14)——模板方法模式
1.模板方法模式介绍 提到模板我们经常会想到简历模板/PPT模板等,以简历模板为例,不同的人可以使用一样的简历模板,在填充内容时根据自己的名字/工作经历等填写自己的内容,从而形成不同的简历.在OO中模 ...
- Git(使用码云)
使用GitHub时,国内的用户经常遇到的问题是访问速度太慢,有时候还会出现无法连接的情况(原因你懂的). 如果我们希望体验Git飞一般的速度,可以使用国内的Git托管服务——码云(gitee.com) ...
- eDEX-UI
eDEX-UI A science fiction terminal emulator disigned for large touchscreen that runs on all major OS ...
- 细说log4j之概述
log4j官网:https://logging.apache.org/ log4j目前存在2个版本:log4j 1.x 和log4j 2.x,目前官方主推2.x版本(log4j 1.x已于2015.0 ...
- 从零开始学HTTP (二) HTTP结构与基础
HTTP结构与基础 这篇文章中,我们主要针对HTTP\1.1版本进行介绍 请求报文和响应报文 请求报文 请求报文由客户端发出,其格式为: 请求方法 请求URI 协议版本 可选的请求首部字段和内容实体, ...
- 从零开始学HTTP (一)网络基础
网络基础 web发展史 下面列出了web发展中几个重要的历史结点 1990年 HTTP/0.9问世(HTTP/0.9含有HTTP1.0之前版本的意思,这时HTTP并未作为标准被公布) CERN(欧洲核 ...
- C# RichTextBox插入带颜色数据
#region 日志记录.支持其他线程访问 public delegate void LogAppendDelegate(Color color, string text); public void ...
- Ubuntu中创建、删除、更改、移动文件的命令
1.创建一个目录 $ sudo mkdir <目录名> 2.删除一个非空目录下的一切 $ sudo rm -rf <目录名> 3.将文件file1,更改文件名为file ...
- 使用Excel过滤重复数据
如题 由于数据太多,没有办法人工过滤,所以借助Excel 我的数据是这样的 需要找出里面重复的数据 首先,选中需要筛选的数据,点击开始 --> 条件格式 --> 突出显示单元格规则 --& ...