CF809D-Hitchhiking in the Baltic States【FhqTreap】

正题

题目链接:https://www.luogu.com.cn/problem/CF809D


正题

题目链接:https://www.luogu.com.cn/problem/CF809D


题目大意

有一个长度为nnn的序列aaa,要求ai∈[li,ri]a_i\in[l_i,r_i]ai[li,ri],要求使得aaa的最长严格上升子序列最长。

1≤n≤3×105,1≤li≤ri≤1091\leq n\leq 3\times 10^5,1\leq l_i\leq r_i\leq 10^91n3×105,1liri109


解题思路

考虑一下暴力的做法,我们设fif_ifi表示在目前的序列中后面加个数字iii为结尾时的最长上升子序列,那么显然fff是单调不降的。

同理由于是严格上升,所以我们fff不可能一次升222的值,也就是fi≤fi−1+1f_i\leq f_{i-1}+1fifi1+1。所以我们可以考虑维护fi=fi−1+1f_i=f_{i-1}+1fi=fi1+1的位置,也就是维护fff的差分数组中的111的位置。

考虑新加入一个[l,r][l,r][l,r]时的变化,那对于所有i∈[l+1,r+1]i\in[l+1,r+1]i[l+1,r+1]都有fi=max{fi,fj+1}(j<i)f_i=max\{f_i,f_j+1\}(j<i)fi=max{fi,fj+1}(j<i),注意到111位置的变化我们可以得出一下结论,当修改[l,r][l,r][l,r]时需要

  1. [l+1,r][l+1,r][l+1,r]中所有111的后面那个111移动到这个111的后一位。
  2. [l+1,r][l+1,r][l+1,r]中的第一个111移动到l+1l+1l+1

这个操作看起来很难实现,实际上我们可以将第一个视为将[l+1,r+1][l+1,r+1][l+1,r+1]中的111往后移一格。

我们用FhqTreap维护111的位置,然后把(r,∞)(r,\infty)(r,)中第一个111删除,[l+1,r][l+1,r][l+1,r]中的所有111往后移一格,再在l+1l+1l+1这个位置插一个111就好了。

时间复杂度:O(nlog⁡n)O(n\log n)O(nlogn)


code

#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
const int N=3e5+10;
int n,cnt,rt,w[N],dat[N],lazy[N],siz[N],t[N][2];
void Downdata(int x){if(!lazy[x])return;for(int i=0;i<2;i++){if(!t[x][i])continue;lazy[t[x][i]]+=lazy[x];w[t[x][i]]+=lazy[x];}lazy[x]=0;return;
}
int NewNode(int val){siz[++cnt]=1;dat[cnt]=rand();w[cnt]=val;return cnt;
}
void PushUp(int x){siz[x]=siz[t[x][0]]+siz[t[x][1]]+1;return;
}
void Split(int &x,int &y,int p,int k){if(!p){x=y=0;return;}Downdata(p);if(w[p]<=k)x=p,Split(t[x][1],y,t[p][1],k);else y=p,Split(x,t[y][0],t[p][0],k);PushUp(p);return;
}
int Merge(int x,int y){Downdata(x);Downdata(y);if(!x||!y)return x|y;if(dat[x]<dat[y]){t[x][1]=Merge(t[x][1],y);PushUp(x);return x;}else{t[y][0]=Merge(x,t[y][0]);PushUp(y);return y;}return x|y;
}
int Findk(int x,int k){if(siz[t[x][0]]>=k)return Findk(t[x][0],k);if(siz[t[x][0]]+1==k)return x;return Findk(t[x][1],k-siz[t[x][0]]-1);
}
int main()
{
//	freopen("vague.in","r",stdin);
//	freopen("vague.out","w",stdout);srand(19260817);scanf("%d",&n);for(int i=1,l,r;i<=n;i++){scanf("%d%d",&l,&r);int x,y,z;l++;Split(x,y,rt,l-1);Split(y,z,y,r);if(z){int v=w[Findk(z,1)],nu;Split(nu,z,z,v);}if(y)lazy[y]++,w[y]++;y=Merge(NewNode(l),y);y=Merge(y,z);rt=Merge(x,y);}printf("%d\n",siz[rt]);return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/317641.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Divide by Zero 2021 and Codeforces Round #714 (Div. 2)

Divide by Zero 2021 and Codeforces Round #714 (Div. 2) 题号题目知识点AArray and PeaksBAND SequencesCAdd OneDGCD and MSTECost EquilibriumFSwapping Problem

新数据革命:开源图形化数据引擎Hawk5发布

Hawk是一款开源图形化的爬虫和数据清洗工具&#xff0c;GitHub Star超过2k&#xff0c;前几代版本介绍如下&#xff1a;Hawk3: 终于等到你: 图形化开源爬虫Hawk 3发布!Hawk2: 120项优化: 超级爬虫Hawk 2.0重磅发布&#xff01;Hawk1: 如何从互联网采集海量数据&#xff1f;租房…

11.6模拟:总结

250pts 1003010020 好的地方是没有挂分吧 T4还用假复杂度过了20 但是T2其实是可做的 关键就是对模型的转化 换个角度考虑每条边的贡献 思路就豁然开朗了 T4确实是神仙题 不太可做 qwq 加油吧OvO

[TJOI2018]智力竞赛 (匈牙利)

description 题目描述 小豆报名参加智力竞赛&#xff0c;他带上了 n个好朋友作为亲友团一块来参加比赛。 比赛规则如下&#xff1a;一共有 m道题目&#xff0c;每个人都有 1 次答题机会&#xff0c;每次答题为选择一道题目回答&#xff0c;在回答正确后&#xff0c;可以从这个…

P6944-[ICPC2018 WF]Gem Island【数学期望,dp】

正题 题目链接:https://www.luogu.com.cn/problem/P6944 题目大意 有nnn颗不同颜色的宝石&#xff0c;每次随机选择一颗复制&#xff0c;重复ddd次&#xff0c;求最后宝石数前rrr的颜色的宝石数之和的期望值。 1≤r≤n,d≤3001\leq r\leq n,d\leq 3001≤r≤n,d≤300 解题思路…

Educational Codeforces Round 107 (Rated for Div. 2)

Educational Codeforces Round 107 (Rated for Div. 2) 题号题目知识点AReview Site签到BGCD Length思维构造CYet Another Card Deck思维DMin Cost String构造题EColorings and Dominoes思维题&#xff0c;构造题FChainwordGChips on a Board A 题意&#xff1a; 有3种评论员…

ASP.NET Core如何在ActionFilterAttribute里做依赖注入

点击蓝字关注我在ASP.NET Core里&#xff0c;我们可以使用构造函数注入很方便地对Controller&#xff0c;ViewComponent等部件做依赖注入。但是如何给过滤器ActionFilterAttribute也用上构造函数注入呢&#xff1f;问题我的博客系统里有个用来删除订阅文件缓存的ActionFilter&a…

NOIP2012:疫情控制(二分、贪心、树上倍增)

解析 二分的单调性较为明显&#xff0c;一路推导下去的性质都不算太难想&#xff0c;正解的思路还是不难想到的 但从头到尾都实现很考验思维的严密性和代码能力 然后我就双重被考验挂了qwq 第一交的时候一个地方把倍增的dis数组写成pl&#xff0c;判断封口也有问题… 但竟然有…

[八省联考2018]劈配 (匈牙利)

description 一年一度的综艺节目《中国新代码》又开始了。Zayid 从小就梦想成为一名程序员&#xff0c;他觉得这是一个展示自己的舞台&#xff0c;于是他毫不犹豫地报名了。 轻车熟路的 Zayid 顺利地通过了海选&#xff0c;接下来的环节是导师盲选&#xff0c;这一阶段的规则…

Codeforces Round #715 (Div. 2)

Codeforces Round #715 (Div. 2) 题号题目知识点AAverage HeightBTMT DocumentCThe Sports Festival区间dpDBinary Literature构造题EAlmost SortedFComplete the MST A 题意&#xff1a; 如果两个相邻的数的和是偶数&#xff0c;则贡献为1 如何排序使得贡献值最大 题解&am…

YbtOJ-森林之和【dp】

正题 题目大意 一个节点的权值定义为它度数的平方&#xff0c;求所有nnn个点的有标号森林的所有节点权值和。 1≤n,T≤51031\leq n,T\leq 5\times 10^31≤n,T≤5103 解题思路 首先因为所有节点本质相同&#xff0c;所以我们可以只考虑一个节点所有情况下的权值和。 然后考虑…

CF1322B:Present(异或、two pointers)

解析 想到了按位&#xff0c;但卡在了进位… qwq 当时总是想一位一位往后转化&#xff0c;但是那样确实做不了 判断第k位时把每个数的前k-1位提出来 sort一下 再维护双指针&#xff0c;就可以很方便的统计进位的个数了 代码 #include<bits/stdc.h> using namespace st…

助力苏州、星火相传,广苏两地微软技术俱乐部交流纪实

2019年1月19日时值二十四节气“大寒”前夕&#xff0c;江南水乡冬日的寒气盖不住苏州.NET开发者的热情&#xff0c;就在这一天苏州微软技术俱乐部成立了并举办了第一场大型的线下交流活动。星火相传2018年12月8日广州.NET微软技术俱乐部举办了恢复以来的第一场大型线下技术交流…

[CTSC2017]吉夫特(思维+巧妙)

description 戳我看题目 solution 显然只要选出来的子序列有一个组合数为偶数&#xff0c;最后取模 222 的结果都会是零 有一个结论&#xff1a;当且仅当n&mm时&#xff0c;CnmC_n^mCnm​为奇数 所以我们要选的子序列&#xff0c;任意相邻两位中后一位的下标和前一位的…

cf1511B. GCD Length

cf1511B. GCD Length 题意&#xff1a; 定义gcd(x,y) z 现在给你a&#xff0c;b&#xff0c;c三个数字&#xff0c;含义分别是 不带前导0的x是由a个数字构成的 不带前导0的y是由b个数字构成的 不带前导0的z是由c个数字构成的 题解&#xff1a; 很明显构造题&#xff0c;但…

微软技术专家为您解读深度学习

随着阿尔法狗、无人驾驶、智能翻译的横空出世&#xff0c;“人工智能”这个已经存在60多年的词语&#xff0c;仿佛一夜之间重新成为热词。同时被科技圈和企业界广泛提及的还有“机器学习”“深度学习”“神经网络”…… 但如此喧嚣热烈的气氛之下&#xff0c;大部分人对这一领域…

CF1322C:Instant Noodles

解析 神仙题了属于是 设SiS_iSi​为右侧第i个点连向的左侧点的集合 然后把所有SiS_iSi​ 相同的点合并成一个点&#xff08;就称为新点吧&#xff09;&#xff0c;点权相加 合并后的所有点权的gcd&#xff08;设为w吧&#xff09;就是答案 为什么&#xff1f; 首先一个显然的…

cf 1511 D. Min Cost String

cf 1511 D. Min Cost String 题意&#xff1a; 我们规定一个字符串的费用为存在一个i和j(i<j),然后s[i] s[j] && s[i1] s[j1]&#xff0c;组成字符串的字符必须是前k位 现在给你字符串的长度n和k&#xff0c;怎样构造使得费用最少 题解&#xff1a; 其实第一个…

「LibreOJ NOI Round #2」不等关系 (dp+NTT分治)

description 戳我看题目哦 solution 有一道非常相似的题目 一棵树&#xff0c;每条边限制两个端点的大小关系&#xff08;限制 a[u]>a[v]a[u]>a[v]a[u]>a[v] 或 a[u]<a[v]a[u]<a[v]a[u]<a[v]&#xff09; 求有多少种符合要求的排列aaa满足整棵树的限制。n…

Loj#2460-「POI2010」桥Bridges【网络流,欧拉回路】

正题 题目链接:https://loj.ac/p/2460 题目大意 给出nnn个点mmm条边的一张无向图&#xff0c;每条边双向的权值不同&#xff0c;求一条经过的最大权值最小的欧拉回路。 2≤n≤1000,1≤m≤200002\leq n\leq 1000,1\leq m\leq 200002≤n≤1000,1≤m≤20000 解题思路 显然我们可…