luogu2253 好一个一中腰鼓!
先说一个小trick,一开始我们把他赋值成是红、白相间的,查询就查询的是全红或全白即可。
然后就可以做啦
题解里面好像都是线段树
暴力的题解好像都被del了
貌似暴力交上去也过不了了
然后我想说
分块大法好!
把同学们他分成\(\lfloor\sqrt N\rfloor\)块
每块维护八个信息:
左边连续白长度,右边连续白长度,块内连续白长度,是否全白,
左边连续红长度,右边连续红长度,块内连续红长度,是否全红,
记录两个不变的信息:
id(废话),块的长度
每次更新,找到那个同学在哪个块,整块全部暴力更新,根号N
怎么更新,整个快全扫一遍,统计白的数量和红的数量能把是否全白全红做了,中途统计当前连续白红数量能把最长块内连续长度做了
然后从块左端往右扫,右端往左扫,把左右两端的长度高了
每次查询,也是\(\sqrt N\),乱搞搞
怎么搞,先枚举两种颜色,然后枚举所有区块,更新一个当前能延伸的长度,如果这个区块全是一种颜色就+=(可以连上),否则就直接等于他右端的长度,具体看代码
复杂度大概\(O(M\sqrt N)\)
由于我经常用调试输出,所以我就没有删除调试输出
#include <cstdio>
#include <iostream>
#include <cmath>
using namespace std;
int n, m, size;
int a[20010], id[20010];
int len[200], l[200], r[200];
struct info
{
bool all;
int l, r, x;
}b[200][2];
int query();
void print()
{
printf("输出调试信息\n");
for (int i = 1; i <= n; i++)
printf("%d%c", a[i], i == n ? '\n' : ' ');
for (int i = 1; i <= id[n]; i++)
{
printf("第%d块 (%d, %d)", i, l[i], r[i]);
for(int t = 0; t <= 1; t++)
printf("[%d %d %d %d]%c", b[i][t].all, b[i][t].l, b[i][t].x, b[i][t].r, t?'\n':' ');
}
printf("当前答案%d\n", query());
}
//更新区块x
void update(int x)
{
// printf("更新了区块%d\n", x);
int t[2] = {0, 0}, f[2] = {0, 0};
b[x][0].x = b[x][1].x = 0;
for (int i = l[x]; i <= r[x]; i++)
{
t[a[i]]++;
f[a[i]]++;
if(a[i] != a[i - 1])
{
b[x][a[i - 1]].x = max(b[x][a[i - 1]].x, f[a[i - 1]]);
f[a[i - 1]] = 0;
}
}
b[x][a[r[x]]].x = max(b[x][a[n]].x, f[a[r[x]]]);
b[x][0].all = (t[0] == len[x]);
b[x][1].all = (t[1] == len[x]);
b[x][a[l[x]]].l = 1;
b[x][a[l[x]] ^ 1].l = 0;
b[x][a[r[x]]].r = 1;
b[x][a[r[x]] ^ 1].r = 0;
for (int i = l[x] + 1; a[i] == a[i - 1] && i <= r[x]; i++)
b[x][a[l[x]]].l++;
for (int i = r[x] - 1; a[i] == a[i + 1] && i >= l[x]; i--)
b[x][a[r[x]]].r++;
}
//查询当前状态的最大值
int query()
{
int maxlength[2] = {0, 0}, nowlength[2] = {0, 0};
for (int t = 0; t <= 1; t++)
{
for (int i = 1; i <= id[n]; i++)//枚举所有区块
{
maxlength[t] = max(maxlength[t], b[i][t].l + nowlength[t]);
maxlength[t] = max(maxlength[t], b[i][t].x);
if(b[i][t].all == 1)
nowlength[t] += len[i];
else
nowlength[t] = b[i][t].r;
}
maxlength[t] = max(maxlength[t], nowlength[t]);
}
return max(maxlength[0], maxlength[1]);
}
int main()
{
scanf("%d%d", &n, &m);
for (int i = 1; i <= n; i++)
a[i] = (i & 1);
size = sqrt(n);
for (int i = 1; i <= n; i++)
{
id[i] = (i - 1) / size + 1;
len[id[i]]++;
if ((i - 1) % size == 0)
l[id[i]] = i;
if (i % size == 0)
r[id[i]] = i;
}
r[id[n]] = n;
for (int i = 1; i <= id[n]; i++)
update(i);
// print();
for (int x, i = 1; i <= m; i++)
{
scanf("%d", &x);
a[x] ^= 1;
update(id[x]);
// print();
printf("%d\n", query());
}
return 0;
}
瞎扯几句
据说写分快是对出题人的不尊重??但是这题难度标签对我不尊重2333。。。
一个线段树模板就是绿题了,这题黄题 显然不用线段树能过,所以我就写了分块
经验/启示:以后懒得写线段树但是又比较勤快可以试试分块
luogu2253 好一个一中腰鼓!的更多相关文章
- 洛谷 P2253 好一个一中腰鼓! 题解
P2253 好一个一中腰鼓! 题目背景 话说我大一中的运动会就要来了,据本班同学剧透(其实早就知道了),我萌萌的初二年将要表演腰鼓[喷],这个无厘头的题目便由此而来. Ivan乱入:"忽一人 ...
- 洛谷P2253 好一个一中腰鼓!
题目背景 话说我大一中的运动会就要来了,据本班同学剧透(其实早就知道了),我萌萌的初二年将要表演腰鼓[喷],这个无厘头的题目便由此而来. Ivan乱入:“忽一人大呼:‘好一个安塞腰鼓!’满座寂然,无敢 ...
- 洛谷 P2253 好一个一中腰鼓!
题目背景 话说我大一中的运动会就要来了,据本班同学剧透(其实早就知道了),我萌萌的初二年将要表演腰鼓[喷],这个无厘头的题目便由此而来. Ivan乱入:“忽一人大呼:‘好一个安塞腰鼓!’满座寂然,无敢 ...
- P2253 好一个一中腰鼓!
题意:给你一个序列,初始是0,每次一个操作,把一个数^=1 每次求出最长01串的长度 正解:线段树(虽然暴力能过) 对于每个区间,记录三个值 lmax,以l为首的01串长度 rmax,以r为尾的01串 ...
- 「Luogu P2253 好一个一中腰鼓!」
就这道题的理论难度来说绿题是有点低了,但是这道题的实际难度来看,顶多黄题,所以建议加强数据或出数据升级版. 前置芝士 线段树:具体可以看我的另一篇文章. 具体做法 暴力的方法想必都会,所以来讲一下正解 ...
- 把一个一中的字段更新另一个表中的t-sql
UPDATE dbo.CommDescr SET Descr=(SELECT ba.content FROM dbo.blog_article ba WHERE ba.id=3) WHERE Comm ...
- noip2017考前整理(未完)
快考试了,把我以前写过的题回顾一下.Noip2007 树网的核:floyd,推出性质,暴力.Noip2008 笨小猴:模拟Noip2008 火柴棒等式:枚举Noip2008 传纸条:棋盘dpNoip2 ...
- mybatis 常用
1.新增时获得主键 <insert ...> <selectKey resultType="java.lang.Integer" keyProperty=&quo ...
- [HNOI2018]爆零记
Day 0 完全不知道做什么. 打了一个splay板子,还没调出来emmmmm 不想做题目,最后做的一题是[HNOI2016]的超(sha)难(bi)题网络. 当我希望省选能出一下树剖时,旁边的大佬跟 ...
随机推荐
- JavaScript 中对小数取整的常用函数
常见的js截取小数的方法 1.丢弃小数部分,保留整数部分 js:parseInt(7/2) 2.向上取整,有小数就整数部分加1 js: Math.ceil(7/2) 3,四舍五入. js: Math. ...
- 基于RFC5321使用ncat发送邮件
今天和同事学习到的这个方法,学习了,记录一下: [root@localhost ~]# ncat TeamServer.localdomain ESMTP Postfix EHLO l00.win - ...
- 2016.3.7 Word2007编号设置
1.点击下图红圈出的下拉箭头 2.点击下图新建样式按钮 3.在弹出窗口中,设置名称AAA(方便稍后的查找修改),样式类型改为列表,点击编号 4.在弹出的窗口中以此设置各级标题的编号样式,保存后设置成功 ...
- 2015.3.12Arinc424 Tools中SiniArincCls.csParserFile(string sFile)函数正则表达式理解
原文: string RegEx1 = @"(\[ITEM\]\s*=[\S\s]*?(?=\[ITEM\])|\[ITEM\]\s*=[\S\s]*)";//用来识别主记录和后续 ...
- Linux 正文处理命令及tar vi 编辑器 homework
作业一: 1) 将用户信息数据库文件和组信息数据库文件纵向合并为一个文件/1.txt(覆盖) cat /etc/passwd /etc/group >/1.txt 2) 将用户信息数据库文件和用 ...
- 微信开发准备(一)--Maven仓库管理新建WEB项目
转自:http://www.cuiyongzhi.com/post/13.html 在我们的项目开发中经常会遇到项目周期很长,项目依赖jar包特别多的情况,所以我们经常会在项目中引入Maven插件,建 ...
- mysql使用存储过程插入数据后,参数为中文的为?或乱码
最近了解了一下mysql存储过程,之前版本的mysql不支持存储过程,5.0版本后就可以支持存储过程的使用:恰好笔者下载使用版本为5.6.20: 做了一个给表插入数据的简单存储过程,发现打开表后汉字全 ...
- javaScript之NodeList
NodeList对象 是DOM操作取出的集合(实际上是基于DOM结构动态查询的结果),用来保存一组有序的节点,可以通过位置来访问这些节点,它并不是array的实例. Nodelist最大的特点就是它的 ...
- python爬虫--编码问题y
1)中文网站爬取下来的内容中文显示乱码 Python中文乱码是由于Python在解析网页时默认用Unicode去解析,而大多数网站是utf-8格式的,并且解析出来之后,python竟然再以Unicod ...
- centos系统查看本机IP地址
centos系统查看本机IP地址,输入 ifconfig -a查看 centos查询上网公网IP输入 curl ifconfig.me 命令即可查看 centos查询上网网关IP,tracepath ...