看标程的代码这么短,看我的....

难道是静态LCA模板太长了?

/*
HDU 6074 - Phone Call [ LCA,并查集 ] | 2017 Multi-University Training Contest 4
题意:
给一棵树,定义集合S(u,v)为u到v路径上所有的点
给出 m 个 <S(u1,v1)|S(u2,v2) , w > ,意思为集合里面的点互相距离为 w
求 1 能到的所有点和该生成树的最小权值
分析:
将所有线路按代价从小到大排序,对于每条线路(a,b,c,d)
分别把S(a,b)和S(c,d)合并到 LCA,最后再把两个 LCA 合并即可
再用f(i)表示i向上第一个与i不在同一个连通块的点, 就可用并查集压缩路径
*/
#include <bits/stdc++.h>
using namespace std;
#define LL long long
const int N = 100005;
const int Q = 200005;
vector<int> G[N];
namespace LCA{
struct Query {
int v, q;
}; vector <Query> query[N];
int ans[Q], f[N], vis[N];
int sf(int x) {
return x == f[x] ? x : f[x] = sf(f[x]);
}
void init() {
memset(ans, -1, sizeof(ans));
for (int i = 0; i < N; i++) {
vis[i] = 0;
f[i] = i;
query[i].clear();
}
}
void adq(int u, int v, int id) {
query[u].push_back(Query{v, id});
query[v].push_back(Query{u, id});
}
void LCA(int u) {
f[u] = u;
vis[u] = 1;
for (auto& x : query[u]) {
if (vis[x.v] && ans[x.q] == -1)
ans[x.q] = sf(x.v);
}
for (auto& v : G[u]) {
if (vis[v]) continue;
LCA(v);
f[v] = u;
}
}
}
int pre[N];
void dfs(int u, int fa) {
pre[u] = fa;
for (auto v : G[u]) {
if (v == fa) continue;
dfs(v, u);
}
}
int f[N], num[N];
LL res[N];
int sf(int x){
return x == f[x] ? x : f[x] = sf(f[x]);
}
int same[N];
int Same(int x) {
return x == same[x] ? x : same[x] = Same(same[x]);
}
int w;
void join(int a, int b){
a = sf(a), b = sf(b);
if (a == b) return;
f[b] = a;
num[a] += num[b];
res[a] += res[b] + w;
}
struct Node {
int a1, b1, a2, b2, w;
int c1, c2;
}e[N];
bool cmp(Node a, Node b) {
return a.w < b.w;
}
void solve(int a, int fa) {
while (Same(a) != Same(fa)) {
a = Same(a);
join(pre[a], a);
same[a] = pre[a];
}
}
int t, n, m;
int main() {
scanf("%d", &t);
while (t--) {
for (int i = 0; i < N; i++) G[i].clear();
LCA::init();
scanf("%d%d", &n, &m);
for (int i = 1; i < n; i++) {
int u, v; scanf("%d%d", &u, &v);
G[u].push_back(v);
G[v].push_back(u);
}
int Q = 0;
for (int i = 1; i <= m; i++) {
scanf("%d%d%d%d%d", &e[i].a1, &e[i].b1, &e[i].a2, &e[i].b2, &e[i].w);
e[i].c1 = ++Q;
LCA::adq(e[i].a1, e[i].b1, Q);
e[i].c2 = ++Q;
LCA::adq(e[i].a2, e[i].b2, Q);
}
LCA::LCA(1);
for (int i = 1; i <= m; i++) {
e[i].c1 = LCA::ans[e[i].c1];
e[i].c2 = LCA::ans[e[i].c2];
}
dfs(1, 1);
sort(e+1, e+m+1, cmp);
for (int i = 1; i <= n; i++) {
f[i] = same[i] = i;
num[i] = 1;
res[i] = 0;
}
for (int i = 1; i <= m; i++) {
w = e[i].w;
solve(e[i].a1, e[i].c1);
solve(e[i].b1, e[i].c1);
solve(e[i].a2, e[i].c2);
solve(e[i].b2, e[i].c2);
join(e[i].c1, e[i].c2);
}
printf("%d %lld\n", num[sf(1)], res[sf(1)]);
}
}

  

HDU 6074 - Phone Call | 2017 Multi-University Training Contest 4的更多相关文章

  1. HDU 6170 - Two strings | 2017 ZJUT Multi-University Training 9

    /* HDU 6170 - Two strings [ DP ] | 2017 ZJUT Multi-University Training 9 题意: 定义*可以匹配任意长度,.可以匹配任意字符,问 ...

  2. hdu 6301 Distinct Values (2018 Multi-University Training Contest 1 1004)

    Distinct Values Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)T ...

  3. hdu 5288 OO’s Sequence(2015 Multi-University Training Contest 1)

    OO's Sequence                                                          Time Limit: 4000/2000 MS (Jav ...

  4. hdu 5416 CRB and Tree(2015 Multi-University Training Contest 10)

    CRB and Tree                                                             Time Limit: 8000/4000 MS (J ...

  5. HDU 4944 FSF’s game(2014 Multi-University Training Contest 7)

    思路:  ans[n]=  ans[n-1] + { (n,1),(n,2).....(n,n)}  现在任务 是 计算  { (n,1),(n,2).....(n,n)}(k=n的任意因子) 很明显 ...

  6. HDU 4940 Destroy Transportation system(2014 Multi-University Training Contest 7)

    思路:无源汇有上下界可行流判定, 原来每条边转化成  下界为D  上界为 D+B   ,判断是否存在可行流即可. 为什么呢?  如果存在可行流  那么说明对于任意的 S 集合流出的肯定等于 流入的, ...

  7. HDU 4627 The Unsolvable Problem 2013 Multi-University Training Contest 3

    给你一个数 n ( 2 <= n <= 109 ),现在需要你找到一对数a, b (a + b = n),并且使得LCM(a, b)尽可能的大,然后输出最大的 LCM(a, b). (为什 ...

  8. HDU 4869 Turn the pokers (2014 Multi-University Training Contest 1)

    Turn the pokers Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)T ...

  9. hdu 6315 Naive Operations (2018 Multi-University Training Contest 2 1007)

    Naive Operations Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 502768/502768 K (Java/Other ...

随机推荐

  1. [转帖]被HTTP/2漏洞拖累,所有Kubernetes版本受影响

    被HTTP/2漏洞拖累,所有Kubernetes版本受影响 https://www.kubernetes.org.cn/5746.html 服务很重要啊... 低版本都不解决安全问题了.. 不过HTT ...

  2. [百度]将ftp添加到本地映射磁盘的方法

    在桌面上鼠标双击“计算机”,进入“计算机”窗口 2 在“计算机”窗口中,选择“映射网络驱动器” 3 进入“映射网络驱动器”窗口 4 设置盘符,可以使用默认,也可以自己手动设置 5 在“映射网络驱动器” ...

  3. oracle-function-into时为null报错

    oracle-function-into时为null报错 create or replace function P_ADD_CUSTOMER_FOR_CSS_heyt_test(i_cust_name ...

  4. swiper手滑动轮播图后自动轮播失效解决办法

    设置autoplay:true之后,再设置 autoplay:{disableOnInteraction: false} --------------------------------------- ...

  5. php中连接tcp服务的三种方式

    首先需要现有一个 tcp 服务,我们使用 php中的 socket 系列函数实现 <?php //创建socket套接字 $socket = socket_create(AF_INET, SOC ...

  6. antd做form表单的组件共用,利用mapPropsToFields填写默认值

    做单页应用,不管是用Vue还是React,或者其他,有一个重要的原则,就是:组件重用. 既然组件可以重用,那么当添加一个信息,和修改该信息的布局必然是一致的,这时候,最好的方法自然是利用同一个组件,在 ...

  7. spring-cloud 学习四 服务网关

    API Gateway 服务网关在微服务中是一个很重要的组成部分,通过服务网关可以统一向外提供REST API,例如 / 映射到后端应用 /api/user 映射到 user service,  /a ...

  8. C#应用笔记

    1.ref关键字.out关键字——引用传递参数 2.什么时候用DateReader,什么时候用DateSet呢? 3.is操作符.as操作符的使用 4.Eval方法和Bind方法的区别 5.Serve ...

  9. STM32 USB Virtual COM

    STM32 USB Virtual COM USB转串口的功能实现   这次讲的是如何实现USB转串口功能的实现.首先看看工程的布局吧: 我们主要要介绍的文件的在USB_User这个组文件.从上面的截 ...

  10. 【css】display:flex和display:box有什么区别

    说法一: 注意:前者是flex 2012年的语法,也将是以后标准的语法,大部分浏览器已经实现了无前缀版本.后者是2009年的语法,已经过时,是需要加上对应前缀的.所以兼容性的代码,大致如下displa ...