P8936 月下缭乱 Sol
考虑对操作的区间 \([l_i,r_i]\) 的下标进行扫描线而不是对操作的值扫。用 \(m\) 个 set 动态维护 \(x_i\) 对应的操作的下标集合,再用一个可删堆来维护当前所有操作 \(x_i\) 的最大值。这样的话 \(\text{sol}(l,r)=\text{sol}(1,m)\) 必须满足 \([l,r]\) 至少包含一个 \(x_i\) 为当前最大值的操作。
动态维护题目中要求的 \(f_i\),发现题目中要我们支持若干个形如 \(\forall i\in [l,r],f_i\leftarrow \max(f_i,r)\) 的操作,满足 \(x_r\) 为当前最大值或者 \(m+1\)。
每个时间点当前最大值的个数之和是 \(O(n^2)\) 的,但我们发现当你操作了一个 set 里的所有值后,后面再去操作这个 set 剔除掉跟之前重复的操作,只需要操作这个 set 新删去的点现在的前驱后继即可。也就是说,本质不同的对 \(f_i\) 的区间取 max 操作在 \(O(n)\) 级别。
注意到对 \(f_i\) 的区间取 max 反正可以离线,干脆用扫描线+可删堆减少常数。
复杂度是 \(O(n\log n)\),空间复杂度 \(O(n)\)。
然后你发现在出题人的精心策划下 \(O(n)\) 个 set 被卡的又 M 又 T。
去掉所有的 vector,换用 \(O(n)\) 个树状树组维护前驱后继才卡过去。
#include <bits/stdc++.h>
using namespace std;
int read(){
	char c=getchar();int x=0;
	while(c<48||c>57) c=getchar();
	do x=(x<<1)+(x<<3)+(c^48),c=getchar();
	while(c>=48&&c<=57);
	return x;
}
typedef unsigned int ui;
typedef pair<int,int> pii;
const int N=1000003;
int n,m,rk;
int a[N],id[N],len[N],sz[N],lg[N];
pii sins[N],sdel[N],ains[N];
priority_queue<int> que;
int *del[N],base[N],cnt[N];
int *tr[N],trbase[N];
int *od[N],odbase[N];
bitset<N> add;
void upd(int p,int x,int v){
	sz[p]+=v;
	for(int i=id[x];i<=len[p];i+=(i&-i)) tr[p][i-1]+=v;
}
int qry(int p,int x){
	int res=0;
	for(int i=id[x];i;i^=(i&-i)) res+=tr[p][i-1];
	return res;
}
int loc(int p,int v){
	int x=0;
	for(int i=(1<<lg[len[p]]);i;i>>=1)
		if(x+i<=len[p]&&tr[p][x+i-1]<v) v-=tr[p][(x+=i)-1];
	return od[p][x];
}
int main(){
	n=read();m=read();
	for(int i=1;i<=m;++i){
		sins[i]=pii(read(),i);
		sdel[i]=pii(read()+1,i);
		id[i]=++len[a[i]=read()];
	}
	del[1]=base;tr[1]=trbase;od[1]=odbase;lg[0]=-1;
	for(int i=1;i<m;++i){
		del[i+1]=del[i]+len[i];
		tr[i+1]=tr[i]+len[i];
		od[i+1]=od[i]+len[i];
	}
	for(int i=1;i<=m;++i) od[a[i]][id[i]-1]=i,lg[i]=lg[i>>1]+1;
	int ix=1,dx=1;
	sort(sins+1,sins+m+1);
	sort(sdel+1,sdel+m+1);
	for(int i=1;i<=n;++i){
		while(ix<=m&&sins[ix].first<=i){
			int x=sins[ix++].second;
			if(!sz[a[x]]) que.emplace(a[x]);
			upd(a[x],x,1);
		}
		while(dx<=m&&sdel[dx].first<=i){
			int x=sdel[dx++].second;
			upd(a[x],x,-1);
			del[a[x]][cnt[a[x]]++]=x;
		}
		while(!que.empty()&&!sz[que.top()]) que.pop();
		if(que.empty()) continue;
		int mx=que.top();
		if(add[mx]){
			for(int t=0;t<cnt[mx];++t){
				int val=qry(mx,del[mx][t]);
				int rig=m+1,lef=0;
				if(val<sz[mx]) rig=loc(mx,val+1);
				if(val) lef=loc(mx,val);
				ains[++rk]=pii(lef+1,rig);
			}
		}
		else{
			int las=0;
			for(int i=1;i<=sz[mx];++i){
				int x=loc(mx,i);
				ains[++rk]=pii(las+1,x);
				las=x;
			}
			ains[++rk]=pii(las+1,m+1);add.set(mx);
		}
		cnt[mx]=0;
	}
	while(!que.empty()) que.pop();
	unsigned int fa=0,fb=0,fc=0;
	ix=1;sort(ains+1,ains+rk+1);
	for(int i=1;i<=m;++i){
		while(ix<=rk&&ains[ix].first<=i) que.emplace(ains[ix++].second);
		while(!que.empty()&&que.top()<=i) que.pop();
		int tmp=i;
		if(!que.empty()) tmp=que.top();
		unsigned int res=m+1-tmp;
		fa+=res;fb^=res*i;fc+=res*i;
	}
	printf("%u %u %u\n",fa,fb,fc);
	return 0;
}
												
											P8936 月下缭乱 Sol的更多相关文章
- BZOJ 1984: 月下“毛景树” [树链剖分 边权]
		
1984: 月下“毛景树” Time Limit: 20 Sec Memory Limit: 64 MBSubmit: 1728 Solved: 531[Submit][Status][Discu ...
 - 利用 Serial Over Lan(SOL)搭建 XEN 的调试信息输出环境
		
如有转载,请注明出处与本文连接,谢谢! 修改XEN的源码实现额外的功能,需要有一个调试环境来得到XEN的调试信息(有关源码编译并安装 XEN 请阅读我以前的博文:在CentOS下源码安装 Xen并搭建 ...
 - grub的sol
		
http://smcijohnny.blogspot.com/2015/06/linuxsolserial-over-lan.html https://www.hiroom2.com/2016/06/ ...
 - 【BZOJ-1502】月下柠檬树       计算几何 + 自适应Simpson积分
		
1502: [NOI2005]月下柠檬树 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 1017 Solved: 562[Submit][Status] ...
 - 【BZOJ1984】月下“毛景树” 树链剖分+线段树
		
[BZOJ1984]月下"毛景树" Description 毛毛虫经过及时的变形,最终逃过的一劫,离开了菜妈的菜园. 毛毛虫经过千山万水,历尽千辛万苦,最后来到了小小的绍兴一中的校 ...
 - 士兵站队问题sol
		
作者:http://www.cnblogs.com/taoziwel/articles/1859577.html 相类似题目:输油管道问题 [问题描述] 在一个划分成网格的操场上,n个士兵散乱地站在网 ...
 - 【BZOJ-1984】月下“毛景树”   树链剖分
		
1984: 月下“毛景树” Time Limit: 20 Sec Memory Limit: 64 MBSubmit: 1314 Solved: 416[Submit][Status][Discu ...
 - dell ipmi sol
		
http://blog.arnoudvermeer.nl/post/52375062605/howto-setup-ipmi-sol-on-a-dell-r-series-server http:// ...
 - Bzoj 1984: 月下“毛景树”  树链剖分
		
1984: 月下“毛景树” Time Limit: 20 Sec Memory Limit: 64 MBSubmit: 1282 Solved: 410[Submit][Status][Discu ...
 - BZOJ1984: 月下“毛景树”
		
1984: 月下“毛景树” Time Limit: 20 Sec Memory Limit: 64 MBSubmit: 713 Solved: 245[Submit][Status] Descri ...
 
随机推荐
- 关于TCP协议传文件的例子
			
按照惯例,先来进行复习,这也是自学巩固的一个过程 首先是在工程文件PRO里,需要增加network,这个是引用TCP监听套接字和连接套接字的前提 第二部,在服务端头文件server.h进行基础的配置: ...
 - vlan概述
			
一.vlan是什么? vlan顾名思义就是虚拟局域网Virtual Local Area Network,为什么要划分vlan?划分vlan可以控制广播,增强网络安全性,简化网络管理. 二.vlan的 ...
 - windows下创建虚拟环境
			
创建虚拟环境依赖以下两个模块 virtualenv 和virtualenvwrapper-win 1.下载 2.修改环境变量,增加一条 WORKON_HOME:路径 3. 同步配置 去向Pytho ...
 - Scanner进阶使用
			
Scanner 进阶使用 package com.andy.base.scanner; import java.util.Scanner; public class Demo04 { public s ...
 - git clone的时候出现 fatal: unable to access 'https://github.com/...':OpenSSL SSL_read: Connection was reset, errno 10054解决方法
			
git clone的时候出现fatal: unable to access 'https://github.com/...':OpenSSL SSL_read: Connection was rese ...
 - 纠删码在实时视频流中的应用丨Dev for Dev 专栏
			
本文为「Dev for Dev 专栏」系列内容,作者为声网网络体验团队王瑞. 01 背景 在实时音视频通话中,音视频质量受网络丢包影响较大,特别是对于视频. 为什么视频对丢包更敏感呢?通常来说,音频的 ...
 - Flink基本概念及架构
			
1.基本概念 无界和有界数据.任何类型的数据都可以形成一种事件流.信用卡交易.传感器测量.机器日志.网站或移动应用程序上的用户交互记录,所有这些数据都形成一种流.数据可以被作为 无界 或者 有界 流来 ...
 - wsl 中 docker-compose 搭建 kafka 集群出现的外部访问错误
			
在 wsl 中用 docker-compose 搭建了一台 zookeeper + 三台 broker 的 kafka 集群,使用的镜像是 bitnami/kafka,在按照镜像文档运行容器后,发现运 ...
 - Linux无root权限conda初始化
			
pre { overflow-y: auto; max-height: 400px } img { max-width: 500px; max-height: 300px } 1. 给anaconda ...
 - pack.json中的^ ~的区别
			
在版本说明前面还有个符号:'^'(插入符号)和'~'(波浪符号),他们之间的区别:例如: '~'(波浪符号):他会更新到当前minor version(也就是中间的那位数字)中最新的版本.放到我们的例 ...