lg8936题解
虽然这道题的题目标签有颜色段均摊和并查集,但是这道题的做法与这两个算法并无关系。
考虑从询问的右往左扫描数组。设\(g_i\)表示以第\(i\)个询问为左端点,最大的\(g_i\)令\(sol(1,n)=sol(i,g_i)\),则\(f_i=m-g_i+1\)。设\(b\)表示执行完编号为\(1\to m\)操作的数组
设\(a_j\)表示扫到\(i\),最大的\(a_j\)使得执行完\(i\to a_j\)的所有操作后\(a_j=b_j\),则答案等于\(\max(a_{1...n})\)。
考虑在左添加一个第\(i\)个操作如何更新\(a_j\)。显然添加一个操作的结果是把\(x_i=b_i\)且\(l_i\leq i\leq r_i\)的所有\(a_i\)都对\(i\)取\(\min\)
考虑把所有数按照\(b_i\)的值分组,并且把每个组内的元素按照在原数组的下标从小到大编号为\(0,1,2,3...\),那么问题转化成:每次对某组的某个区间对\(i\)取\(\min\)(这个区间可以二分求),并且求出所有组的数的最大值。
由于所有组的数的最大值等于所有组的所有数取\(\max\),所以可以设\(h_i\)表示第\(i\)组的最大值,可以在线段树上区间修改求出\(h\)。
\(a_i\)显然随着\(i\)的降低而降低,所以答案随着\(i\)的减小单调递减。且\(x_i\leq 10^6\),所以可以用桶维护\(x_i\)。
然而这道题的空间只有128MB,所以不能用vector存储线段树,而应该用指针和new分配内存,不然会被卡。
#include<bits/stdc++.h>
using namespace std;
#define N 1000010
int n,m,mn[N*4],l[N],r[N],x[N],va[N],ct[N],*g[N],*h[N];
vector<int>v[N];
void mp(int o,int l,int r,int x,int y,int z){
if(r<x||y<l)
return;
if(x<=l&&r<=y){
mn[o]=max(mn[o],z);
return;
}
int md=(l+r)/2;
mp(o*2,l,md,x,y,z);
mp(o*2+1,md+1,r,x,y,z);
}
void pd(int o,int l,int r,int x){
x=max(x,mn[o]);
if(l==r){
va[l]=x;
return;
}
int md=(l+r)/2;
pd(o*2,l,md,x);
pd(o*2+1,md+1,r,x);
}
void pd(int p,int o){
h[p][o*2]=min(h[p][o*2],h[p][o]);
h[p][o*2+1]=min(h[p][o*2+1],h[p][o]);
g[p][o*2]=min(g[p][o*2],h[p][o]);
g[p][o*2+1]=min(g[p][o*2+1],h[p][o]);
}
void mo(int o,int l,int r,int x,int y,int z,int p){
if(r<x||y<l)
return;
if(x<=l&&r<=y){
h[p][o]=z;
g[p][o]=min(g[p][o],z);
return;
}
pd(p,o);
int md=(l+r)/2;
mo(o*2,l,md,x,y,z,p);
mo(o*2+1,md+1,r,x,y,z,p);
g[p][o]=max(g[p][o*2],g[p][o*2+1]);
}
int fd(int o,int l,int r){
if(l==r)
return o;
int md=(l+r)/2;
return max(fd(o*2,l,md),fd(o*2+1,md+1,r));
}
int main(){
scanf("%d%d",&n,&m);
for(int i=1;i<=m;i++){
scanf("%d%d%d",&l[i],&r[i],&x[i]);
mp(1,1,n,l[i],r[i],x[i]);
}
pd(1,1,n,0);
for(int i=1;i<=n;i++)
v[va[i]].push_back(i);
for(int i=1;i<=m;i++){
l[i]=lower_bound(v[x[i]].begin(),v[x[i]].end(),l[i])-v[x[i]].begin();
r[i]=lower_bound(v[x[i]].begin(),v[x[i]].end(),r[i]+1)-v[x[i]].begin()-1;
}
for(int i=1;i<=1e6;i++)
if(v[i].size()){
int sz=fd(1,0,v[i].size()-1);
g[i]=new int[sz+1];
h[i]=new int[sz+1];
for(int j=0;j<=sz;j++)
g[i][j]=h[i][j]=m+1;
ct[m+1]++;
}
int mx=m+1,lf=0,f;
unsigned int a1=0,a2=0,a3=0;
for(int i=m;i;i--){
if(l[i]>r[i]||!v[x[i]].size())
f=lf;
else{
int sz=v[x[i]].size()-1;
ct[g[x[i]][1]]--;
mo(1,0,sz,l[i],r[i],i,x[i]);
ct[g[x[i]][1]]++;
while(!ct[mx]&&mx)
mx--;
f=m-mx+1;
}
a1^=f*i;
a2+=f*i;
a3+=f;
lf=f;
}
printf("%u %u %u",a3,a1,a2);
}
lg8936题解的更多相关文章
- 2016 华南师大ACM校赛 SCNUCPC 非官方题解
我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...
- noip2016十连测题解
以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...
- BZOJ-2561-最小生成树 题解(最小割)
2561: 最小生成树(题解) Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1628 Solved: 786 传送门:http://www.lyd ...
- Codeforces Round #353 (Div. 2) ABCDE 题解 python
Problems # Name A Infinite Sequence standard input/output 1 s, 256 MB x3509 B Restoring P ...
- 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解
题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...
- 2016ACM青岛区域赛题解
A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Jav ...
- poj1399 hoj1037 Direct Visibility 题解 (宽搜)
http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...
- 网络流n题 题解
学会了网络流,就经常闲的没事儿刷网络流--于是乎来一发题解. 1. COGS2093 花园的守护之神 题意:给定一个带权无向图,问至少删除多少条边才能使得s-t最短路的长度变长. 用Dijkstra或 ...
- CF100965C题解..
求方程 \[ \begin{array}\\ \sum_{i=1}^n x_i & \equiv & a_1 \pmod{p} \\ \sum_{i=1}^n x_i^2 & ...
- JSOI2016R3 瞎BB题解
题意请看absi大爷的blog http://absi2011.is-programmer.com/posts/200920.html http://absi2011.is-programmer.co ...
随机推荐
- 未授权访问漏洞之Redis漏洞复现
前言 未授权访问漏洞简写是SSRF(Server-Side Request Forgery:服务器端请求伪造),是一种服务器端提供了可以从其他服务器获取资源和数据的功能,但没有对目标地址进行过滤和限制 ...
- overflow_auto在flex_1的容器失效
旧文章从语雀迁移过来,原日期为2022-02-22 我们经常使用flex:1来动态分配父容器剩余空间,这时候如果要在容器上增加滚动条,使用overflow: auto可能会失效. 原因: 一般原因:因 ...
- .NET周报【12月第4期 2022-12-31】
祝大家新年快乐! 国内文章 『 再看.NET7』数值类型 https://mp.weixin.qq.com/s/ctiBMPY6Hditk81AzHSRng 在C#中,有int16,用short来定义 ...
- B站地区限制破解方法
B站地区限制破解方法 当我们观看bilibili番剧时,经常会看到"仅限港澳台地区"的字样.那么,有没有一种方法,不需要挂梯子,就可以观看这些被限制的番剧呢? 本教程只适用于bil ...
- [数据结构]广度优先搜索算法(Breadth-First-Search,BFS)
广度优先搜索的概念 广度优先搜索(BFS)类似于二叉树的层序遍历算法,它的基本思想是:首先访问起始顶点v,然后由v出发,依次访问v的各个未被访问过的邻接顶点w1,w2,w3-.wn,然后再依次访问w1 ...
- 使用SQL4Automation让CodeSYS连接数据库
摘要:本文旨在说明面向CodeSYS的数据库连接方案SQL4Automation的使用方法. 1.SQL4Automation简介 1.1.什么是SQL4Automation SQL4Auto ...
- Matplotlib学习笔记1 - 上手制作一些图表吧!
Matplotlib学习笔记1 - 上手制作一些图表吧! Matplotlib是一个面向Python的,专注于数据可视化的模块. 快速上手 这是使用频率最高的几个模块,在接下来的程序中,都需要把它们作 ...
- 迷宫机器人最短路径使用tkinter绘制
起因 我想要写一个玩家和机器对战的迷宫游戏.这个项目我没有写完,我实现了最短机器人路径并绘制在tkinter上,以及玩家移动的功能.更多的关于GUI的设计太花时间了我没有写完. 算法介绍 我在写机器人 ...
- 一个关于sum over的疑问
参考: http://www.cnblogs.com/lanzi/archive/2010/10/26/1861338.html select * from bitest.tmp_0222_zym ; ...
- GF_CLR初始用 - 正式版
参照:DeerGF_Wolong框架使用教程 与tackor老哥的踩坑日记所编写,第二次尝试,总结第一次经验重新来. 点击链接加入群聊[Gf_Wolong热更集合] 一. 部署 HybridCLR(W ...