当前位置: 首页 > news >正文

旅行(LCA)

Description

N-1座桥连接着N个岛屿,每座桥都连接着某两个不同的岛屿,从任意一个岛屿都可以到达所有的其他岛屿,过桥需要缴纳人民币1元的过桥费。
由于某些不可透露的原因,Jason和他的2个小伙伴可以在任意一个岛屿集合,但是希望总过桥费最少。
现在,由你来确定集合的岛屿编号,使得总过桥费最少。

Input Format

第一行有两个整数N和M,表示岛屿的个数和询问次数,岛屿编号从1到N。
接下来N-1行,每行有两个正整数X、Y,表示编号为X的岛屿和编号为Y的岛屿之间有一座桥。
最后还有M行,每行有三个正整数A、B、C,表示Jason和他的两个小伙伴所在岛屿的编号。

Output Format

一共有M行,每行两个整数P、Q,用一个空格隔开。其中第i行表示第i次询问集合的地点在编号为P的岛屿,需要花费的最少过桥费为Q。

Sample Output

5 5
1 2
1 3
2 4
2 5
1 1 1
1 1 2
1 2 3
4 5 3
5 2 3

Sample Output

1 0
1 1
1 2
2 4
2 3

Hint

30%的数据中,N≤200,M≤200;
60%的数据中,N≤2,000,M≤2,000;
100%的数据中,N≤200,000,M≤200,000;

Solution

显然这是一个树形结构,可以发现,3个地点A,B,C,一定存在2对的LCA相同,例如LCA(A,B)==LCA(A,C),那么集合点就在LCA(B,C),画一画图会更好理解

还有几种特殊的情况经检验也符合上述情况

Code

#include <cstdio>
#include <algorithm>
#include <cmath>
#define N 200010
#define M 400010

struct info {int to, nex;} e[M];
int n, m, tot, head[M], fa[N][22], dep[N], _log;
bool vis[N];

void dfs(int u) {
    vis[u] = 1;
    for (int i = 1; dep[u] >= (1 << i); ++i)
        fa[u][i] = fa[fa[u][i - 1]][i - 1];

    for (int i = head[u]; i; i = e[i].nex) {
        int v = e[i].to;
        if (vis[v]) continue;
        dep[v] = dep[u] + 1;
        fa[v][0] = u;
        dfs(v);
    }
}

inline int read() {
    int x = 0, f = 1; char ch = getchar();
    while (ch < '0' || ch > '9') {if (ch == '-')f = -1; ch = getchar();}
    while (ch >= '0' && ch <= '9') {x = x * 10 + ch - '0'; ch = getchar();}
    return x * f;
}

inline void add_edge(int u, int v) {
    e[++tot].to = v;
    e[tot].nex = head[u];
    head[u] = tot;
}

int LCA(int u, int v) {
    if (dep[u] > dep[v])
        std::swap(u, v);

    int d = dep[v] - dep[u];
    for (int i = 0; i <= _log; ++i)
        if (d & (1 << i))
            v = fa[v][i];

    if (u == v) return u;

    for (int i = _log; i >= 0; i--)
        if (fa[u][i] != fa[v][i]) {
            u = fa[u][i];
            v = fa[v][i];
        }

    return fa[u][0];
}

inline void work(int a, int b, int c) {
    int ab = LCA(a, b);
    int ans = dep[a] + dep[b] - 2 * dep[ab] + dep[ab] + dep[c] - 2 * dep[LCA(ab, c)];
    printf("%d %d\n", ab, ans);
}

int main() {
    n = read(), m = read();
    _log = log(n) / log(2);
    for (int i = 1; i < n; ++i) {
        int u = read(), v = read();
        add_edge(u, v);
        add_edge(v, u);
    }
    dfs(1);

    while (m--) {
        int a = read(), b = read(), c = read();
        int ab = LCA(a, b), ac = LCA(a, c), bc = LCA(b, c);
        if (ac == bc) work(a, b, c);
        else if (ab == bc) work(a, c, b);
        else if (ab == ac) work(b, c, a);
    }
    return 0;
}

转载于:https://www.cnblogs.com/void-f/p/7685842.html

相关文章:

  • Linux正则表达式元字符
  • AMD首款APU的价值和机会
  • BMap:JavaScript API
  • Java注释讲解
  • Android前景,前途(转)
  • GPU的线程模型和内存模型
  • 深入浅出ShellExecute
  • 概率校准Probability Calibration
  • PHP漏洞全解(九)-文件上传漏洞
  • 1531 山峰 【栈的应用】
  • Activity 5秒 Broadcast 10秒 Service 20秒
  • Windows 8 C#调用C++编写的Windows运行时组件
  • SQL Server 索引基础知识(1)--- 记录数据的基本格式
  • 计算器--超级low版
  • [原创]JSLint-Toolkit v1.2 - Update with qooxdoo1.3
  • C++回声服务器_9-epoll边缘触发模式版本服务器
  • javascript 哈希表
  • Java到底能干嘛?
  • Median of Two Sorted Arrays
  • PhantomJS 安装
  • php中curl和soap方式请求服务超时问题
  • puppeteer stop redirect 的正确姿势及 net::ERR_FAILED 的解决
  • Solarized Scheme
  • Spark VS Hadoop:两大大数据分析系统深度解读
  • 阿里中间件开源组件:Sentinel 0.2.0正式发布
  • 初识 webpack
  • 分类模型——Logistics Regression
  • 如何学习JavaEE,项目又该如何做?
  • 深入浏览器事件循环的本质
  • 小程序滚动组件,左边导航栏与右边内容联动效果实现
  • 400多位云计算专家和开发者,加入了同一个组织 ...
  • ​什么是bug?bug的源头在哪里?
  • #《AI中文版》V3 第 1 章 概述
  • (31)对象的克隆
  • (39)STM32——FLASH闪存
  • (51单片机)第五章-A/D和D/A工作原理-A/D
  • (done) ROC曲线 和 AUC值 分别是什么?
  • (Mac上)使用Python进行matplotlib 画图时,中文显示不出来
  • (Redis使用系列) SpringBoot中Redis的RedisConfig 二
  • (附源码)springboot炼糖厂地磅全自动控制系统 毕业设计 341357
  • (附源码)ssm高校志愿者服务系统 毕业设计 011648
  • (附源码)计算机毕业设计ssm-Java网名推荐系统
  • (六)软件测试分工
  • (论文阅读31/100)Stacked hourglass networks for human pose estimation
  • (三)模仿学习-Action数据的模仿
  • (十八)三元表达式和列表解析
  • (转)ORM
  • (轉貼) 資訊相關科系畢業的學生,未來會是什麼樣子?(Misc)
  • .NET Framework 3.5中序列化成JSON数据及JSON数据的反序列化,以及jQuery的调用JSON
  • .NET Project Open Day(2011.11.13)
  • .NET简谈互操作(五:基础知识之Dynamic平台调用)
  • .net连接MySQL的方法
  • @transactional 方法执行完再commit_当@Transactional遇到@CacheEvict,你的代码是不是有bug!...
  • [<死锁专题>]
  • [BUUCTF NewStarCTF 2023 公开赛道] week3 crypto/pwn