https://www.luogu.org/problemnew/show/P4374

一看这道题就是一个妙题,然后题解什么树链剖分...珂朵莉树...

还不如并查集来的实在!我们知道并查集本来就是路径压缩的。

比如这题可以树上的路径压缩!! 直接跳到father,就省去大量上跳的过程(因为我们已经计算过了,不存在最优了)。

下面给出题面:

给出n个节点的树,现在有m条边可供替换,对于树上每一条边删除,

为了保证整颗树强连通,需要从给出的边中选出一条添加上,

求对于删除的每一条树边,最小添加上的给出的边的长度。

对于100%的数据 $n \leq 5\times 10^4 $

做法的话就是首先建这棵树然后把每一条边记录它的编号i然后LCA预处理都会的吧

按照边权排序然后枚举这条边可以完成哪些边删除后的替代作用,显然的一个贪心,前面枚举的边权小如果被小边权选过了

那么后面的边即使可以选上也一定比前面的边权大,所以只要可行,我们就使用并查集把这条边直接折叠掉,下次不做遍历。

对于每一条边的答案存在它的末端,可以比较方便处理。暴力找不断按照father跳到lca及以上就行。

code :

# include <cstdio>
# include <algorithm>
using namespace std;
const int N=5e4+;
struct rec{ int u,v,w; }e[N];
struct Edg{ int pre,to,id; }a[N<<];
int n,m,tot;
int dep[N],g[N][],f[N],head[N],arc[N],ans[N];
inline int read()
{
int X=,w=; char c=;
while(c<''||c>'') {w|=c=='-';c=getchar();}
while(c>=''&&c<='') X=(X<<)+(X<<)+(c^),c=getchar();
return w?-X:X;
}
void swap(int &x,int &y){int t=x;x=y;y=t;}
void write(int x)
{
if (x==-) { putchar('-'); putchar(''); return;}
if (x>) write(x/);
putchar(x%+'');
}
void adde(int id,int u,int v)
{
a[++tot].pre=head[u];
a[tot].to=v;
a[tot].id=id;
head[u]=tot;
}
int father(int x)
{
if (f[x]==x) return x;
return f[x]=father(f[x]);
}
bool cmp(rec aa,rec bb){return aa.w<bb.w;}
void dfs(int u,int fath)
{
g[u][]=fath; dep[u]=dep[fath]+;
for (int i=head[u];i;i=a[i].pre) {
int v=a[i].to; if (v==fath) continue;
arc[a[i].id]=v;
dfs(v,u);
}
}
void init()
{
for (int j=;j<=;j++)
for (int i=;i<=n;i++)
g[i][j]=g[g[i][j-]][j-];
}
int lca(int u,int v)
{
if (dep[u]<dep[v]) swap(u,v);
for (int i=;i>=;i--)
if (dep[g[u][i]]>=dep[v]) u=g[u][i];
if (u==v) return u;
for (int i=;i>=;i--)
if (g[u][i]!=g[v][i]) u=g[u][i],v=g[v][i];
return g[u][];
}
int main()
{
n=read();m=read();
int u,v;
for (int i=;i<n;i++) {
u=read();v=read();
adde(i,u,v); adde(i,v,u);
}
dfs(,); init();
for (int i=;i<=m;i++)
e[i]=(rec){read(),read(),read()};
sort(e+,e++m,cmp);
for (int i=;i<=n;i++) f[i]=i,ans[i]=-;
for (int i=;i<=m;i++) {
int w=e[i].w,u=e[i].u,v=e[i].v,Lca=lca(u,v);
for (u=father(u);dep[u]>dep[Lca];u=father(g[u][]))
ans[u]=w,f[u]=g[u][];
for (v=father(v);dep[v]>dep[Lca];v=father(g[v][]))
ans[v]=w,f[v]=g[v][];
}
for (int i=;i<n;i++) write(ans[arc[i]]),putchar('\n');
return ;
}

[并查集+LCA USACO18OPEN ] Disruption的更多相关文章

  1. hdu 2874 Connections between cities (并查集+LCA)

    Connections between cities Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K (J ...

  2. hdu6074[并查集+LCA+思维] 2017多校4

    看了标答感觉思路清晰了许多,用并查集来维护全联通块的点数和边权和. 用另一个up[]数组(也是并查集)来保证每条边不会被重复附权值,这样我们只要将询问按权值从小到大排序,一定能的到最小的边权和与联通块 ...

  3. Gym 100814C Connecting Graph 并查集+LCA

    Description standard input/output Statements Alex is known to be very clever, but Walter does not be ...

  4. Network-POJ3694并查集+LCA

    Network Time Limit: 5000MS   Memory Limit: 65536K       Description A network administrator manages ...

  5. Mobile Phone Network CodeForces - 1023F(并查集lca+修改环)

    题意: 就是有几个点,你掌控了几条路,你的商业对手也掌控了几条路,然后你想让游客都把你的所有路都走完,那么你就有钱了,但你又想挣的钱最多,真是的过分..哈哈 游客肯定要对比一下你的对手的路 看看那个便 ...

  6. HDU6074 Phone Call (并查集 LCA)

    Phone Call Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 524288/524288 K (Java/Others)Tota ...

  7. 习题:过路费(kruskal+并查集+LCA)

    过路费  [问题描述]在某个遥远的国家里,有 n 个城市.编号为 1,2,3,…,n.这个国家的政府修 建了 m 条双向道路,每条道路连接着两个城市.政府规定从城市 S 到城市 T 需 要收取的过路费 ...

  8. BZOJ 4668 冷战(按秩合并并查集+LCA)

    4668: 冷战 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 627  Solved: 303[Submit][Status][Discuss] D ...

  9. [CSP-S模拟测试]:Dash Speed(线段树+并查集+LCA)

    题目描述 比特山是比特镇的飙车圣地.在比特山上一共有$n$个广场,编号依次为$1$到$n$,这些广场之间通过$n−1$条双向车道直接或间接地连接在一起,形成了一棵树的结构. 因为每条车道的修建时间以及 ...

随机推荐

  1. 大话设计模式之模板模式 C#

    学无止境,精益求精 十年河东,十年河西,莫欺少年穷 今天一起探讨模板模式,如下: 一.概念 上一篇文章讲了大话设计模式:原型模式,原型模式主要是通过Clone()方法<深浅复制>,创建新的 ...

  2. 如何使用 GroupBy 计数-Count()

    十年河东,十年河西,莫欺少年穷. 本节探讨的内容很简单,就是如果使用GroupBy计数 提供两种方法:第一:把查询的数据,转化为泛型,然后泛型分组计数. 第二:Linq语句直接分组计数 有如下范例: ...

  3. 【转载】固态硬盘的S.M.A.R.T详解

    文章来源于: 瑞耐斯存储技术 兵哥写这篇文章,是因为在测试的过程中看到了 SSD存在偶尔有性能下降的情况,经分析为S.M.A.R.T命令所导致,虽然这种情况看似不严重,但如果应用在诸如数据采集等关键性 ...

  4. webpack教程(一)——初体验

    首先全局安装webpack,再npm初始化一个项目,并局部安装webpack开发工具 $ npm install webpack -g npm init (项目名称) $ npm install we ...

  5. 如何设置本机电脑的固定IP地址?

    最近使用Loadrunner需要用到IP欺骗,但是我打开设置IP欺骗却提示我:IP向导不支持启用DHCP的网卡.您的卡启用了DHCP或者配置了无效设置.请与系统管理员联系. 我就方了,于是百度了一下, ...

  6. Oracle数据库冷备份与热备份操作梳理

    Oracle数据库的备份方式有冷备份和热备份两种,针对这两种备份的实施过程记录如下: 一.Oracle冷备份 概念数据库在关闭状态下完成所有物理系统文件拷贝的过程,也称脱机备份.适合于非归档模式(即n ...

  7. centos下部署NTP时间服务器同步环境记录

    1)服务端部署 安装所需软件包 [root@test ~]# yum -y install ntp ntpdate 服务端自己先手工同步一次时间. [root@test ~]# ntpdate ntp ...

  8. [linux] VirtualBox复制虚拟机

    环境: Oracle VM VirtualBox 5.0.20 CentOS-6.7-x86_64-minimal.iso 1.复制虚拟机 -->右击休眠状态模板虚拟机,选择复制 -->填 ...

  9. combox的基本应用

    easyui-combox:控件的初始化: 可以在其中进行文字的筛选功能(过滤), 动态加载数据的方法. <!DOCTYPE html><html lang="en&quo ...

  10. Pairproject 移山之道 阅读随笔和一些问题

    首先不得不承认这本书的写作方式很独特,不像其他的计算机类的图书那样枯燥,让人读起来感觉很有意思,他也颠覆了我对计算机类图书的看法,这种写作方式值得我们学习. 先谈谈收获吧.读了两年大学,这是第一次写类 ...