vijos p1881 线段树
题意:点我
我就想问,现在换代码风格还来得及吗?
2015-05-19:线段树进一步加强,看来不用换风格了
维护左右节点左右端颜色和长度即可
#include<cstdio>
#include<iostream>
#include<algorithm>
#include<cstring>
#include<cmath>
#include<queue>
#define lson l,mid,rt<<1
#define rson mid+1,r,rt<<1|1
#define root 1,n,1
#define mid ((l+r)>>1)
#define ll long long
#define cl(a) memset(a,0,sizeof(a))
#define ts printf("*****\n");
using namespace std;
const int MAXN=+;
int sum[MAXN<<],lsum[MAXN<<],rsum[MAXN<<],lc[MAXN<<],rc[MAXN<<];
int n,m,t;
void pushup(int rt,int m)
{
lc[rt]=lc[rt<<];
rc[rt]=rc[rt<<|];
lsum[rt]=lsum[rt<<];
rsum[rt]=rsum[rt<<|];
sum[rt]=max(sum[rt<<],sum[rt<<|]);
if(rc[rt<<]!=lc[rt<<|])
{
sum[rt]=max(sum[rt],rsum[rt<<]+lsum[rt<<|]); if(sum[rt<<]==(m-(m>>)))
{
lsum[rt]=sum[rt<<]+lsum[rt<<|];
}
if(sum[rt<<|]==(m>>))
{
rsum[rt]=sum[rt<<|]+rsum[rt<<];
}
}
}
void build(int l,int r,int rt)
{
sum[rt]=lsum[rt]=rsum[rt]=lc[rt]=rc[rt]=;
if(l==r) return;
build(lson);
build(rson);
}
void update(int pos,int l,int r,int rt)
{
if(l==r)
{
lc[rt]=rc[rt]^=;
return;
}
if(pos<=mid) update(pos,lson);
if(pos>mid) update(pos,rson);
pushup(rt,(r-l+));
}
int main()
{
int i,j,k,q;
scanf("%d%d",&n,&m);
build(root);
int pos;
for(i=;i<m;i++)
{
scanf("%d",&pos);
update(pos,root);
printf("%d\n",sum[]);
}
return ;
}
题解代码
#include<cstdio>
#include <cstring>
#include <algorithm>
#define mid (l+r)/2
#define ls rt<<1,l,mid
#define rs rt<<1|1,mid+1,r
using namespace std;
const int Rn=+;
int N,Q;
struct Node
{
int lc,rc; //左右两端颜色
int ln,rn; //左右两边长度
int val; //长度
}T[Rn<<];
void pushup(int rt,int l,int r)
{
Node &x1=T[rt],x2=T[rt<<],x3=T[rt<< | ];
x1.lc=x2.lc;
x1.rc=x3.rc;
x1.ln=x2.ln;
x1.rn=x3.rn;
x1.val=max(x2.val,x3.val);
if(x2.rc!=x3.lc)
{
x1.val=max(x1.val,x2.rn+x3.ln);
if(x2.val==mid-l+){
x1.ln=x2.val+x3.ln;
}
if(x3.val==r-mid){
x1.rn=x3.val+x2.rn;
}
} }
void build(int rt,int l,int r)
{
Node &S=T[rt];
S.lc=S.rc=S.ln=S.rn=S.val=;
if(l==r)
{
return;
}
build(ls);
build(rs);
} void update(int rt,int l,int r,int x)
{
if(l==r)
{
T[rt].lc=T[rt].rc=T[rt].lc^;
return;
}
if(x<=mid)
{
update(ls,x);
}
if(x>mid)
{
update(rs,x);
}
pushup(rt,l,r);
} int main()
{
#ifndef ONLINE_JUDGE
freopen("1.in","r",stdin);
#endif
int x;
scanf("%d%d",&N,&Q);
build(,,N);
for(int i=;i<Q;i++)
{
scanf("%d",&x);
update(,,N,x);
printf("%d\n",T[].val);
}
return ; }
vijos p1881 线段树的更多相关文章
- Vijos P1103 校门外的树【线段树,模拟】
校门外的树 描述 某校大门外长度为L的马路上有一排树,每两棵相邻的树之间的间隔都是1米.我们可以把马路看成一个数轴,马路的一端在数轴0的位置,另一端在L的位置:数轴上的每个整数点,即0,1,2,……, ...
- Vijos P1066 弱弱的战壕【多解,线段树,暴力,树状数组】
弱弱的战壕 描述 永恒和mx正在玩一个即时战略游戏,名字嘛~~~~~~恕本人记性不好,忘了-_-b. mx在他的基地附近建立了n个战壕,每个战壕都是一个独立的作战单位,射程可以达到无限(“mx不赢定了 ...
- Vijos P1448 校门外的树【多解,线段树,树状数组,括号序列法+暴力优化】
校门外的树 描述 校门外有很多树,有苹果树,香蕉树,有会扔石头的,有可以吃掉补充体力的…… 如今学校决定在某个时刻在某一段种上一种树,保证任一时刻不会出现两段相同种类的树,现有两个操作: K=1,K= ...
- Vijos 1404 遭遇战 - 动态规划 - 线段树 - 最短路 - 堆
背景 你知道吗,SQ Class的人都很喜欢打CS.(不知道CS是什么的人不用参加这次比赛). 描述 今天,他们在打一张叫DUSTII的地图,万恶的恐怖分子要炸掉藏在A区的SQC论坛服务器!我们SQC ...
- vijos 1659 河蟹王国 线段树区间加、区间查询最大值
河蟹王国 Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 https://vijos.org/p/1659 Description 河蟹王国有一位河蟹国王,他 ...
- 【vijos】1750 建房子(线段树套线段树+前缀和)
https://vijos.org/p/1750 是不是我想复杂了.... 自己yy了个二维线段树,然后愉快的敲打. 但是wa了两法.......sad 原因是在处理第二维的更新出现了个小问题,sad ...
- 【vijos】1881 闪烁的繁星(线段树+特殊的技巧)
https://vijos.org/p/1881 这场比赛太难了sad.所以我都没做.. 这题一开始我竟然不会sad(本来就不会),然后我继续yy..yy了好久,竟然yy了个什么可拆分的并查集?(sa ...
- [vijos]1066弱弱的战壕<线段树>
题目链接:https://www.vijos.org/p/1066 这道题没什么难度,只是要一个排序然后就是线段树的基本套路模版了 但是我还是讲一讲思路吧: 给出的是坐标x,y,当一个点的x,y都小于 ...
- Vijos 1083 小白逛公园(线段树)
线段树,每个结点维护区间内的最大值M,和sum,最大前缀和lm,最大后缀和rm. 若要求区间为[a,b],则答案max(此区间M,左儿子M,右儿子M,左儿子rm+右儿子lm). ----------- ...
随机推荐
- 彻底搞懂字符编码(unicode,mbcs,utf-8,utf-16,utf-32,big endian,little endian...)[转]
最近有一些朋友常问我一些乱码的问题,和他们交流过程中,发现这个编码的相关知识还真是杂乱不堪,不少人对一些知识理解似乎也有些偏差,网上百度, google的内容,也有不少以讹传讹,根本就是错误的(例如说 ...
- Mysql中truncate table和delete语句的区别
Mysql中的truncate table和delete语句都可以删除表里面所有数据,但是在一些情况下有些不同! 例子: truncate table gag; (1)truncate table删除 ...
- bash脚本里su命令执行
俩种方法 1.可以使用 <<EOF 参数实现. 脚本内容:cat test.sh代码如下: #!/bin/bashsu - test <<EOFpwd;exit;EOF 2.当 ...
- git内部原理
Git 内部原理 无论是从之前的章节直接跳到本章,还是读完了其余章节一直到这——你都将在本章见识到 Git 的内部工作原理 和实现方式. 我们发现学习这部分内容对于理解 Git 的用途和强大至关重要. ...
- Python基础:内置异常(未完待续)
本文根据Python 3.6.5的官文Built-in Exceptions编写,不会很详细,仅对Python的内置异常进行简单(重难点)介绍——很多异常都可以从名称判断出其意义,罗列所有的内置异常. ...
- 使用vs2015编辑c++模板程序报错2019
笔者这几天在熟悉vs2015工具编辑c++,(从前用的都是vc++6.0).发现还真是不容易使用,简单的一个小程序会报错一大堆你看不懂的问题.现将我发现的重要的一个问题呈现给大家. 在使用类模板设计对 ...
- MinGW-MSYS Bundle Win32编译ffmpeg 生成DLL并加入X264模块
组件资源站点 1)MinGW-MSYS Bundle http://sourceforge.net/projects/mingwbundle/files/ 2)yasm汇编器 http://yasm. ...
- 编程六月定律 | 外刊IT评论网
编程六月定律 上周,我被迫对一个很老的项目做一些修改.麻烦是,当开始着手时,我真的记不清这个项目究竟有多老了. 这实际上是我使用Codeigniter实现的第一个MVC项目.打开项目文件后,很多东西都 ...
- ES按资源类型统计个数
一.目标:统计各类型资源的个数,输出详细报表 http://10.10.6.225:9200/dsideal_db/t_resource_info/ _mapping { "propert ...
- PHP性能调优---php-fpm - 启动参数及重要配置详解
约定几个目录/usr/local/php/sbin/php-fpm/usr/local/php/etc/php-fpm.conf/usr/local/php/etc/php.ini 一,php-fpm ...