来自FallDream的博客,未经允许,请勿转载,谢谢。


给定一张无向图,有点权,要支持单点修改点权和询问从一个点到另一个点不重复经过节点的路径上点权最小值的最小值。

n,m<=10^5

考虑求出图的点双连通分量,然后每个点向所有包含他的点双连边,这样我们可以得到一棵树。

询问就变成了询问与树上两点间路径上的点相邻的点中权值的最小值。

我们考虑对每个点双开一个堆,把所有儿子的信息扔进去。这样但点修改只需要修改它父亲那个点双就行了。

然后用树剖+线段树来支持查询即可。注意特判lca的父亲节点。

复杂度O(nlog^2n)

#include<iostream>
#include<cstring>
#include<cstdio>
#include<vector>
#include<queue>
#include<map>
#define P(x,y) make_pair(min(x,y),max(x,y))
#define pa pair<int,int>
#define MN 200000
#define N 262144
using namespace std;
inline int read()
{
int x=,f=;char ch=getchar();
while(ch<''||ch>''){if(ch=='-')f=-;ch=getchar();}
while(ch>=''&&ch<=''){x=x*+ch-'';ch=getchar();}
return x*f;
}
pa q[MN*+];map<pa,bool> mp;vector<int> v[MN+];priority_queue<pa,vector<pa>,greater<pa> > s[MN+];
int n,m,Q,tp=,b[MN+],head[MN+],dfn[MN+],low[MN+],mark[MN+],dn=,cnt=,size[MN+];
int fa[MN+],w[MN+],vis[MN+],num=,bel[MN+],dep[MN+],top[MN+],mx[MN+],T[N*+];
struct edge{int to,next;}e[MN*+];
inline void ins(int f,int t)
{
e[++cnt]=(edge){t,head[f]};head[f]=cnt;
e[++cnt]=(edge){f,head[t]};head[t]=cnt;
}
inline void Ins(int f,int t)
{
v[f].push_back(t);
v[t].push_back(f);
}
void Tarjan(int x,int fa)
{
dfn[x]=low[x]=++dn;int son=;
for(int i=head[x];i;i=e[i].next)
if(e[i].to!=fa)
{
if(!dfn[e[i].to])
{
++son;
q[++tp]=make_pair(x,e[i].to),Tarjan(e[i].to,x);
low[x]=min(low[x],low[e[i].to]);
if(low[e[i].to]>=dfn[x])
{
b[x]=;++num;
while(q[tp+]!=make_pair(x,e[i].to))
{
int a=q[tp].first,b=q[tp].second;
if(bel[a]!=num) Ins(a,num+n);
if(bel[b]!=num) Ins(b,num+n);
--tp;bel[a]=num;bel[b]=num;
}
}
}
else
{
low[x]=min(low[x],dfn[e[i].to]);
if(dfn[x]>dfn[e[i].to]) q[++tp]=make_pair(x,e[i].to);
}
}
if(son==&&!fa) b[x]=;
}
void Pre(int x,int f)
{
fa[x]=f;size[x]=;mx[x]=;
for(int i=;i<v[x].size();++i)
if(v[x][i]!=f)
{
dep[v[x][i]]=dep[x]+;
Pre(v[x][i],x);
size[x]+=size[v[x][i]];
if(size[v[x][i]]>size[mx[x]]) mx[x]=v[x][i];
}
} void Dfs(int x,int Tp)
{
top[x]=Tp;dfn[x]=++dn;
if(mx[x]) Dfs(mx[x],Tp);
for(int i=;i<v[x].size();++i)
if(v[x][i]!=mx[x]&&v[x][i]!=fa[x])
Dfs(v[x][i],v[x][i]);
}
void Renew(int x,int k){for(T[x+=N]=k;x>>=;)T[x]=min(T[x<<],T[x<<|]);}
int Query(int l,int r)
{
int mx=1e9;
for(l+=N-,r+=N+;l^r^;l>>=,r>>=)
{
if(~l&) mx=min(mx,T[l+]);
if( r&) mx=min(mx,T[r-]);
}
return mx;
}
void Add(int x,int v,int k)
{
++vis[v];
s[x].push(make_pair(k,v));
while(!s[x].empty()&&w[s[x].top().second]!=s[x].top().first) s[x].pop();
int K=s[x].size()?s[x].top().first:;Renew(dfn[x],K);
}
int Solve(int x,int y)
{
int mx=1e9;
while(top[x]!=top[y])
{
if(dep[top[x]]<dep[top[y]]) swap(x,y);
mx=min(mx,Query(dfn[top[x]],dfn[x]));
x=fa[top[x]];
}
if(dfn[x]>dfn[y]) swap(x,y);
mx=min(mx,Query(dfn[x],dfn[y]));
if(x>n&&fa[x]) mx=min(mx,w[fa[x]]);
return mx;
}
char st[];
int main()
{
n=read();m=read();Q=read();
for(int i=;i<=n;++i) w[i]=read();
for(int i=;i<=m;++i) ins(read(),read());
Tarjan(,);memset(T,,sizeof(T));
dn=;Pre(,);Dfs(,);
for(int i=;i<=n;++i)
{
Renew(dfn[i],w[i]);
if(fa[i]) Add(fa[i],i,w[i]);
}
for(int i=;i<=Q;++i)
{
scanf("%s",st+);int x=read(),y=read();
if(st[]=='A') printf("%d\n",Solve(x,y));
else
{
w[x]=y,Renew(dfn[x],y);
if(fa[x]) Add(fa[x],x,y);
}
}
return ;
}

Codeforces278E Tourists的更多相关文章

  1. 【Codefoces487E/UOJ#30】Tourists Tarjan 点双连通分量 + 树链剖分

    E. Tourists time limit per test: 2 seconds memory limit per test: 256 megabytes input: standard inpu ...

  2. Tourists

    Tourists 时间限制: 5 Sec  内存限制: 64 MB 题目描述 In Tree City, there are n tourist attractions uniquely labele ...

  3. CF487 E. Tourists [点双连通分量 树链剖分 割点]

    E. Tourists 题意: 无向连通图 C a w: 表示 a 城市的纪念品售价变成 w. A a b: 表示有一个游客要从 a 城市到 b 城市,你要回答在所有他的旅行路径中最低售价的最低可能值 ...

  4. 【CF487E】Tourists(圆方树)

    [CF487E]Tourists(圆方树) 题面 UOJ 题解 首先我们不考虑修改,再来想想这道题目. 我们既然要求的是最小值,那么,在经过一个点双的时候,走的一定是具有较小权值的那一侧. 所以说,我 ...

  5. 每日英语:Foreign Tourists Skip Beijing

    Overseas tourists continued to shun Beijing through 2013. shun:避开,避免,回避 Amid rising pollution and a ...

  6. L192 Virgin Galactic Completes Test of Spaceship to Carry Tourists

    Virgin Galactic says its spacecraft designed to launch tourists into space completed an important te ...

  7. UOJ #30. [CF Round #278] Tourists

    UOJ #30. [CF Round #278] Tourists 题目大意 : 有一张 \(n\) 个点, \(m\) 条边的无向图,每一个点有一个点权 \(a_i\) ,你需要支持两种操作,第一种 ...

  8. [UOJ30]/[CF487E]Tourists

    [UOJ30]/[CF487E]Tourists 题目大意: 一个\(n(n\le10^5)\)个点\(m(m\le10^5)\)条边的无向图,每个点有点权.\(q(q\le10^5)\)次操作,操作 ...

  9. Tourists——圆方树

    CF487E Tourists 一般图,带修求所有简单路径代价. 简单路径,不能经过同一个点两次,那么每个V-DCC出去就不能再回来了. 所以可以圆方树,然后方点维护一下V-DCC内的最小值. 那么, ...

随机推荐

  1. 201621123031 《Java程序设计》第3周学习总结

    Week03-面向对象入门 1. 本周学习总结 初学面向对象,会学习到很多碎片化的概念与知识.尝试学会使用思维导图将这些碎片化的概念.知识点组织起来.请使用工具画出本周学习到的知识点及知识点之间的联系 ...

  2. javabean 是什么?

    JavaBean规范 Bean的中文含义是“豆子”,顾名思义,JavaBean是指一段特殊的Java类, 就是有默然构造方法,只有get,set的方法的java类的对象. 专业点解释是: JavaBe ...

  3. day-4 python多进程编程知识点汇总

    1. python多进程简介 由于Python设计的限制(我说的是咱们常用的CPython).最多只能用满1个CPU核心.Python提供了非常好用的多进程包multiprocessing,他提供了一 ...

  4. .Net Core SignalR 实时推送信息

    以前一直没用成功过SignalR(.net asp),最近几天又参考了对应的文档,最终调成功啦. 开始之前,应该注意: 一定要.Net Core 2.1.0以上的SDK. VS2017 15.6以上的 ...

  5. python django的ManyToMany简述

    Django的多对多关系 在Django的关系中,有一对一,一对多,多对多的关系 我们这里谈的是多对多的关系 ==我们首先来设计一个用于示例的表结构== # -*- coding: utf-8 -*- ...

  6. Web Api 返回图片流

    public class TestController : ApiController { public HttpResponseMessage GetImg() { //获取文件的绝对路径 stri ...

  7. SpringCloud的Hystrix(二) 某消费者应用(如:ui、网关)访问的多个微服务的断路监控

    一.验证断路保护监控是否管理多个消费者 app 1.第1个消费者应用:访问自己封装rest服务 saleProd 2.第2个消费者应用:第二个应用没有反应 说明 1.每个应用实例的断路保护机制,只对本 ...

  8. EasyUI 数据网格行过滤

    前段时间发现一个GridView很有用的功能,可以筛选数据,实现起来很简单 一.添加一个引用,这个可以自己去网上下载 <script type="text/javascript&quo ...

  9. Java8新特性第1章(Lambda表达式)

    在介绍Lambda表达式之前,我们先来看只有单个方法的Interface(通常我们称之为回调接口): public interface OnClickListener { void onClick(V ...

  10. Properties文件读写问题

    项目需要在Properties配置文件中设置一些配置属性,其中包含一些中文属性.经过一上午的奋斗终于圆满解决问题. 读取Properties文件所有属性 Map<String, String&g ...