mex性质学习

E.Complicated Computations

如果一个区间的mex=amex=amex=a,满足以下条件:

  • 区间未出现aaa
  • 区间出现1→a−11\to a-11a1

因此若考虑是否存在一个区间的mex值是aaa,我们尝试把整个区间以aaa为端点划分成若干段,只要每一段内(不含端点a)中出现1→a−11\to a-11a1那么就存在一个区间的mex值是aaa
a…a…a…a…a…a…aa\dots a\dots a\dots a\dots a\dots a\dots aaaaaaaa
即只要有一个…\dots存在1→a−11\to a-11a1那么就存在区间mex=amex=amex=a

那么如何确定…\dots存在1→a−11\to a-11a1
不妨假设两个a的位置一个是LLL,一个是RRR,那么我们现在判定[L+1,R−1][L+1,R-1][L+1,R1]的区间是否存在1→a−11\to a-11a1。那么不难发现1→a−11\to a-11a1最后一次出现的位置>L>L>L
由此用权值线段树维护每一个数最后一次出现的位置,并且记录上一次某数出现的位置查询即可。

#define IO ios::sync_with_stdio(false);cin.tie();cout.tie(0)
#pragma GCC optimize(2)
#include<set>
#include<map>
#include<cmath>
#include<queue>
#include<random>
#include<bitset>
#include<string>
#include<vector>
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
#include<unordered_map>
#include<unordered_set>
using namespace std;
typedef long long ll;
typedef pair<int,int> pii;
const int mod=1e9+7;
const int N=100010;
int a[N],n;
bool st[N];
int last[N];
int pos[N<<2];
void modify(int u,int l,int r,int k,int x)
{if(l==r) {pos[u]=x;return;}int mid=l+r>>1;if(k<=mid) modify(u<<1,l,mid,k,x);else modify(u<<1|1,mid+1,r,k,x);pos[u]=min(pos[u<<1],pos[u<<1|1]);
}
int query(int u,int l,int r,int L,int R)
{if(l>=L&&r<=R) return pos[u];int mid=l+r>>1;if(R<=mid)return query(u<<1,l,mid,L,R);else if(L>mid)return query(u<<1|1,mid+1,r,L,R);else return min(query(u<<1,l,mid,L,R),query(u<<1|1,mid+1,r,L,R));
}
int main()
{IO;int T=1;//cin>>T;for(int ca=1;ca<=T;ca++){cin>>n;for(int i=1;i<=n;i++) cin>>a[i];for(int i=1;i<=n;i++){if(a[i]!=1) st[1]=1;if(a[i]>1&&query(1,1,n,1,a[i]-1)>last[a[i]]) st[a[i]]=1;last[a[i]]=i;modify(1,1,n,a[i],i);}for(int i=2;i<=n+1;i++) //枚举到n+1有可能有区间的mex=n+1if(query(1,1,n,1,i-1)>last[i]) st[i]=1;int res=1;while(st[res]) res++;cout<<res<<'\n';}return 0;
}

这题竟然还卡时间?用build版本的线段树就TLE,只能查询时传递区间。。。

本题还可以效仿下面题目的做法,用线段树维护mex,每次区间修改aia_iai 时便可能存在区间的mex是 aia_iai

#include<bits/stdc++.h>using namespace std;
typedef long long ll;
typedef pair<int,int> pii;
const int mod=1e9+7;
const int N=200010;
int a[N],n;
int mex[N],ne[N],pos[N];
bool st[N];
struct node
{int l,r;ll tag;ll mn,mx;
}t[N<<2];
void pushup(int u)
{t[u].mn=min(t[u<<1].mn,t[u<<1|1].mn);t[u].mx=max(t[u<<1].mx,t[u<<1|1].mx);
}
void build(int u,int l,int r)
{t[u]={l,r,-1,0x3f3f3f3f,-0x3f3f3f3f};if(l==r){t[u].mn=t[u].mx=mex[l]; return;}int mid=l+r>>1;build(u<<1,l,mid);build(u<<1|1,mid+1,r);pushup(u);
}
void pushdown(int u)
{if(t[u].tag==-1) return;t[u<<1].tag=t[u].tag;t[u<<1|1].tag=t[u].tag;t[u<<1].mn=t[u].tag;t[u<<1|1].mn=t[u].tag;t[u<<1].mx=t[u].tag;t[u<<1|1].mx=t[u].tag;t[u].tag=-1;
}
bool modify(int u,int l,int r,int x)
{if(l>r) return 0;if(t[u].mx<=x) return 0;if(t[u].l>=l&&t[u].r<=r&&t[u].mn>x){t[u].tag=x;t[u].mn=x;t[u].mx=x;return 1;}pushdown(u);int mid=t[u].l+t[u].r>>1;bool ok=0;if(l<=mid) ok|=modify(u<<1,l,r,x);if(r>mid)  ok|=modify(u<<1|1,l,r,x);pushup(u);return ok;
}int vis[N];int main()
{scanf("%d",&n);for(int i=1;i<=n;i++) scanf("%d",&a[i]);int now=1;for(int i=1;i<=n;i++){st[a[i]]=1;while(st[now]) now++;mex[i]=now;vis[now]=1;}//for(int i=1;i<=n;i++) cout<<mex[i]<<' ';cout<<'\n';for(int i=0;i<=n+1;i++) pos[i]=n+1;for(int i=n;i;i--){ne[i]=pos[a[i]];pos[a[i]]=i;}build(1,1,n);for(int i=1;i<=n;i++){int l=i+1,r=ne[i]-1;if(modify(1,l,r,a[i])) vis[a[i]]=1;}//for(int i=1;i<=n;i++) cout<<vis[i]<<' ';cout<<'\n';int res=1; while(vis[res]) res++;printf("%d\n",res);return 0;
}

Hdu. Mex

大佬题解
mex(1,i)mex(1,i)mex(1,i)具有单调递增的性质。

#include<bits/stdc++.h>#pragma GCC optimize(2)
using namespace std;
typedef long long ll;
typedef pair<int,int> pii;
const int mod=1e9+7;
const int N=200010;
int a[N],n;
int mex[N],ne[N],pos[N];
bool st[N];
struct node
{int l,r;ll s;ll lazy;
}tree[N<<2];
void pushup(int u)
{tree[u].s=tree[u<<1].s+tree[u<<1|1].s;
}
void build(int u,int l,int r)
{tree[u]={l,r,0,-1};if(l==r){tree[u].s=mex[l]; return;}int mid=l+r>>1;build(u<<1,l,mid);build(u<<1|1,mid+1,r);pushup(u);
}
void pushdown(int u)
{if(tree[u].lazy==-1) return;int lenl=tree[u<<1].r-tree[u<<1].l+1;int lenr=tree[u<<1|1].r-tree[u<<1|1].l+1;tree[u<<1].s=1ll*lenl*tree[u].lazy;tree[u<<1|1].s=1ll*lenr*tree[u].lazy;tree[u<<1].lazy=tree[u].lazy;tree[u<<1|1].lazy=tree[u].lazy;tree[u].lazy=-1;
}
void modify(int u,int l,int r,int x)
{if(tree[u].l>=l&&tree[u].r<=r){tree[u].s=1ll*x*(tree[u].r-tree[u].l+1);tree[u].lazy=x;return;}pushdown(u);int mid=tree[u].l+tree[u].r>>1;if(l<=mid) modify(u<<1,l,r,x);if(r>mid) modify(u<<1|1,l,r,x);pushup(u);
}
ll query(int u,int l,int r)
{if(tree[u].l>=l&&tree[u].r<=r) return tree[u].s;pushdown(u);int mid=tree[u].l+tree[u].r>>1;ll v=0;if(l<=mid) v+=query(u<<1,l,r);if(r>mid) v+=query(u<<1|1,l,r);return v;
}
int main()
{while(scanf("%d",&n),n){for(int i=1;i<=n;i++){scanf("%d",&a[i]);if(a[i]>n) a[i]=n+1;}for(int i=0;i<=n+1;i++) st[i]=0;int now=0;for(int i=1;i<=n;i++){st[a[i]]=1;while(st[now]) now++;mex[i]=now;}for(int i=0;i<=n+1;i++) pos[i]=n+1;for(int i=n;i;i--){ne[i]=pos[a[i]];pos[a[i]]=i;}build(1,1,n);ll res=0;for(int i=1;i<=n;i++){res+=query(1,i,n);int l=i,r=ne[i]-1;while(l<r){int mid=l+r>>1;if(query(1,mid,mid)>a[i]) r=mid;else l=mid+1;}if(query(1,l,l)>a[i]) modify(1,l,ne[i]-1,a[i]);}printf("%lld\n",res);}return 0;
}

同时维护最大最小值,势能去掉二分

#include<bits/stdc++.h>using namespace std;
typedef long long ll;
typedef pair<int,int> pii;
const int mod=1e9+7;
const int N=200010;
int a[N],n;
int mex[N],ne[N],pos[N];
bool st[N];
struct node
{int l,r;ll s;ll tag;ll mn,mx;
}t[N<<2];
void pushup(int u)
{t[u].s=t[u<<1].s+t[u<<1|1].s;t[u].mn=min(t[u<<1].mn,t[u<<1|1].mn);t[u].mx=max(t[u<<1].mx,t[u<<1|1].mx);
}
void build(int u,int l,int r)
{t[u]={l,r,0,-1,0x3f3f3f3f,-0x3f3f3f3f};if(l==r){t[u].s=t[u].mn=t[u].mx=mex[l]; return;}int mid=l+r>>1;build(u<<1,l,mid);build(u<<1|1,mid+1,r);pushup(u);
}
void pushdown(int u)
{if(t[u].tag==-1) return;int lenl=t[u<<1].r-t[u<<1].l+1;int lenr=t[u<<1|1].r-t[u<<1|1].l+1;t[u<<1].s=1ll*lenl*t[u].tag;t[u<<1|1].s=1ll*lenr*t[u].tag;t[u<<1].tag=t[u].tag;t[u<<1|1].tag=t[u].tag;t[u<<1].mn=t[u].tag;t[u<<1|1].mn=t[u].tag;t[u<<1].mx=t[u].tag;t[u<<1|1].mx=t[u].tag;t[u].tag=-1;
}
void modify(int u,int l,int r,int x)
{if(t[u].mx<=x) return;if(t[u].l>=l&&t[u].r<=r&&t[u].mn>x){t[u].s=1ll*x*(t[u].r-t[u].l+1);t[u].tag=x;t[u].mn=x;t[u].mx=x;return;}pushdown(u);int mid=t[u].l+t[u].r>>1;if(l<=mid) modify(u<<1,l,r,x);if(r>mid)  modify(u<<1|1,l,r,x);pushup(u);
}
ll query(int u,int l,int r)
{if(t[u].l>=l&&t[u].r<=r) return t[u].s;pushdown(u);int mid=t[u].l+t[u].r>>1;ll v=0;if(l<=mid) v+=query(u<<1,l,r);if(r>mid) v+=query(u<<1|1,l,r);return v;
}
int main()
{while(scanf("%d",&n),n){for(int i=1;i<=n;i++){scanf("%d",&a[i]);if(a[i]>n) a[i]=n+1;}for(int i=0;i<=n+1;i++) st[i]=0;int now=0;for(int i=1;i<=n;i++){st[a[i]]=1;while(st[now]) now++;mex[i]=now;}for(int i=0;i<=n+1;i++) pos[i]=n+1;for(int i=n;i;i--){ne[i]=pos[a[i]];pos[a[i]]=i;}build(1,1,n);ll res=0;for(int i=1;i<=n;i++){res+=query(1,i,n);int l=i,r=ne[i]-1;if(l<=r) modify(1,l,r,a[i]);}printf("%lld\n",res);}return 0;
}

在这里插入图片描述
两者时间复杂度对比,效果还挺明显。

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

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

相关文章

AServer - 基于Asp.net core Kestrel的超迷你http服务器

AServer是基于ASP.NET Core Kestrel封装的一个超迷你http服务器。它可以集成进你的Core程序里&#xff0c;用来快速的响应Http请求&#xff0c;而不需要集成整个ASP.NET Core MVC 框架。一&#xff1a;什么是ASever&#xff1f;AServer就像它的名字一样&#xff0c;Just a serv…

基于Service fabric + Ocelot + Identity Server4 + 52ABP 的案例展示

10.24-27 大会Microsoft Tech Summit 2018 在上海举办&#xff0c;我 有幸受邀成为这场大会的讲师。Microsoft Tech Summit 2018 微软技术暨生态大会将于10月24日至27日在上海世博中心举行&#xff0c;这也会是国内举办的最后一届 Tech Summit&#xff0c;2019 年开始会以 Micr…

Feature Flag 功能发布控制

背景产品在新功能发布前&#xff0c;可能会采取小流量测试的方式&#xff0c;或者在确定方案前使用A/B测试来衡量。一般开发人员会跟运维同学合作&#xff0c;通过一些现有平台切换机器或者流量来实现。本文介绍了另外一种简便的方式&#xff0c;并解释了其在持续集成上的应用&…

SmartSql 动态代理仓储

SmartSql源码&#xff1a;https://github.com/Ahoo-Wang/SmartSql1|1简介动态代理仓储(SmartSql.DyRepository)组件是SmartSql非常独特的功能&#xff0c;它能简化SmartSql的使用。对业务代码除了配置几乎没有侵入。可以说使用SmartSqlContainer是原始方法&#xff0c;而DyRepo…

Ocelot简易教程(六)之重写配置文件存储方式并优化响应数据

本来这篇文章在昨天晚上就能发布的&#xff0c;悲剧的是写了两三千字的文章居然没保存&#xff0c;结果我懵逼了。今天重新来写这篇文章。今天我们就一起来探讨下如何重写Ocelot配置文件的存储方式以及获取方式。作者&#xff1a;依乐祝原文地址&#xff1a;https://www.cnblog…

.NET Core实践系列之SSO-跨域实现

前言接着上篇的《.net core实践系列之SSO-同域实现》&#xff0c;这次来聊聊SSO跨域的实现方式。这次虽说是.net core实践&#xff0c;但是核心点使用jquery居多。建议看这篇文章的朋友可以先看上篇《.net core实践系列之SSO-同域实现》做一个SSO大概了解。源码地址&#xff1a…

.NET 源代码库指南

微软.NET开发团队在博客上&#xff08;https://blogs.msdn.microsoft.com/dotnet/2018/10/15/guidance-for-library-authors/&#xff09;发布了.NET Library Guidance的第一个版本。这是一系列全新的文章&#xff0c;指导你为.NET创建高质量代码库。该指南包含我们已确定的适用…

基于gRPC服务发现与服务治理的方案

重温最少化集群搭建&#xff0c;我相信很多朋友都已经搭建出来&#xff0c;基于Watch机制也实现了出来&#xff0c;相信也有很多朋友有了自己的实现思路&#xff0c;但是&#xff0c;很多朋友有个疑问&#xff0c;我API和服务分离好了&#xff0c;怎么通过服务中心进行发现呢&a…

CentOS ASP.NET Core Runtime Jexus跨平台布署

.net core 开源和跨平台&#xff0c;能布署到当前主流的Windows&#xff0c;Linux&#xff0c;macOS 系统上。本篇我们将在 Linux 系统上使用 ASP.NET Core Runtime 和 Jexus 布署运行 ASP.NET Core 网站。Linux 系统选的是 CentOS 7.4 64位.NET Core 安装的是 ASP.NET Core Ru…

疾病预测和天气分析练习赛

肝了半天再加一个晚上。。 之前学了一小段时间的TensorFlow&#xff0c;但是今天练习赛时发现根本没啥用。。。第一阶段早就做完了&#xff0c;今天做的都是第二阶段&#xff0c;都是啥玩意题 又是偏度&#xff0c;又是求系数&#xff0c;又是拟合KNN&#xff0c;真的把人看吐…

微软智能云三驾马车Azure、Office 365、Dynamics 365齐聚中国

Dynamics 365计划于2019年春落地中国&#xff1b;Windows Server 2019、Office 2019正式商用&#xff1b;SQL Server 2019、Azure Sphere 公开预览&#xff1b;Microsoft Azure 更新数十项云服务与功能&#xff0c;聚焦物联网与边缘。2018年10月25日&#xff0c;上海 —— 2018…

ASP.NET Core SignalR中的流式传输

什么是流式传输&#xff1f;流式传输是这一种以稳定持续流的形式传输数据的技术。流式传输的使用场景有些场景中&#xff0c;服务器返回的数据量较大&#xff0c;等待时间较长&#xff0c;客户端不得不等待服务器返回所有数据后&#xff0c;再进行相应的操作。这时候使用流式传…

独立版Jexus配置SSL,支持https访问

一、申请证书【腾讯免费证书】二、验证DNS&#xff0c;即解析域名。记录类型选择 TXT &#xff0c;主机记录与证书上的主机记录保持一致&#xff0c;记录值也与证书上的记录值保持一致三、等待DNS验证与CA轮询&#xff0c;轮询成功后即可下载证书四、Jexus用到的是Nginx中的证书…

莫比乌斯反演+例题

参考1 参考2 参考3 问题引入&#xff1a; 入门题 给定N和M和D&#xff0c;求满足1<x<N,1<y<M且gcd(x,y)D的点对(x,y)的个数 1<N,M<1000000 莫比乌斯函数 μ μ(n) 1 , n1 μ(n) (-1)k, np1 * p2 * … * Pk &#xff08;x有奇数个质因子时为-1&#xff…

.net core通过多路复用实现单服务百万级别RPS吞吐

多路复用其实并不是什么新技术&#xff0c;它的作用是在一个通讯连接的基础上可以同时进行多个请求响应处理。对于网络通讯来其实不存在这一说法&#xff0c;因为网络层面只负责数据传输&#xff1b;由于上层应用协议的制订问题&#xff0c;导致了很多传统服务并不能支持多路复…

微软官宣:史上最贵开发工具 75亿美金收购GitHub

微软副总裁红衣主教Scott Gu今天的一封邮件结束了这笔软件历史上最大收购案&#xff0c;微软给全球开发人员的开源代码仓库GitHub投入了75亿美金&#xff0c;确保这一平台的持续健康发展。GitHub为啥愿意被收购&#xff1f;“软件工程这个事情&#xff0c;从来就不是一笔好生意…

C# 中使用面向切面编程(AOP)中实践代码整洁

1. 前言最近在看《架构整洁之道》一书&#xff0c;书中反复提到了面向对象编程的 SOLID 原则&#xff08;在作者的前一本书《代码整洁之道》也是被大力阐释&#xff09;&#xff0c;而面向切面编程&#xff08;Aop&#xff09;作为面向对象编程的有力补充&#xff0c;对实践整洁…

微软对开发者献真爱,全面支持开源,加速研发云升级

全球首秀&#xff1a;支持 Java 和 Python 的 Visual Studio Live Share 协作服务与 IntelliCode 人工智能辅助编程&#xff0c;适用于物联网和智能边缘的自动机器学习能力&#xff08;Auto ML&#xff09;&#xff1b;Visual Studio App Center 提供一站式跨平台移动应用开发体…

Ocelot简易教程(七)之配置文件数据库存储插件源码解析

上篇文章Ocelot简易教程&#xff08;六&#xff09;之重写配置文件存储方式并优化响应数据 给大家分享了如何集成我写的一个Ocelot扩展插件把Ocelot的配置存储到数据库中。并没有对实现原理进行相应的阐述。今天抽空把实现的原理给大家说道说道。明白原理后&#xff0c;大家就可…

ASP.NET Core 2调用Azure云上的PowerBI报表展示

在开发企业应用中&#xff0c;报表功能是当之无愧的重头戏&#xff0c;如何将数据通过合适的报表呈现出来成为每个项目人员必需面临的问题。而找到一款合适的报表往往都需要考率价格、开发、风格、支撑等因素。那么&#xff0c;我在这里给大家介绍一款由微软提供的可视化报表工…