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

【景区导游——LCA】

题目

代码

#include <bits/stdc++.h>
using namespace std;
using ll = long long;
const int N = 1e5 + 10;
const int M = 2 * N;
int p[N][18], d[N], a[N];
ll dis[N][18]; //注意这里要开long long
int h[N], e[M], ne[M], idx, w[M];
int n, k;
void add(int a, int b, int c)
{
    e[idx] = b, ne[idx] = h[a], h[a] = idx, w[idx++] = c;
}
void dfs(int u)
{
    for (int i = h[u]; ~i; i = ne[i])
    {
        int j = e[i];
        if (d[j])
            continue;
        d[j] = d[u] + 1;
        p[j][0] = u;
        dis[j][0] = w[i];
        for (int k = 1; k <= 17; k++)
        {
            p[j][k] = p[p[j][k - 1]][k - 1];
            dis[j][k] = dis[j][k - 1] + dis[p[j][k - 1]][k - 1];
        }
        dfs(j);
    }
}
ll lca(int a, int b)
{
    ll retv = 0;

    if (d[a] < d[b])
        swap(a, b);
    for (int i = 17; i >= 0; i--)
    {
        if (d[p[a][i]] >= d[b])
        {
            retv += dis[a][i];
            a = p[a][i];
        }
    }

    if (a == b)
        return retv;

    for (int i = 17; i >= 0; i--)
    {
        if (p[a][i] != p[b][i])
        {
            retv += dis[a][i];
            retv += dis[b][i];
            a = p[a][i];
            b = p[b][i];
        }
    }

    retv += dis[a][0];
    retv += dis[b][0];

    return retv;
}
int main()
{
    memset(h, -1, sizeof h);

    cin >> n >> k;
    for (int i = 1; i < n; i++)
    {
        int a, b, c;
        cin >> a >> b >> c;
        add(a, b, c);
        add(b, a, c);
    }
    
    d[1] = 1;
    dfs(1);
    
    ll tmp = 0;
    cin >> a[1];
    for (int i = 2; i <= k; i++)
    {
        cin >> a[i];
        tmp += lca(a[i - 1], a[i]);
    }

    for (int i = 1; i <= k; i++)
    {
        ll ans = tmp;
        if (i == 1)
            ans -= lca(a[1], a[1 + 1]);
        else if (i == k)
            ans -= lca(a[k - 1], a[k]);
        else
        {
            ans -= lca(a[i - 1], a[i]);
            ans -= lca(a[i], a[i + 1]);
            ans += lca(a[i - 1], a[i + 1]);
        }

        cout << ans << ' ';
    }

    return 0;
}


http://www.kler.cn/a/522147.html

相关文章:

  • C++ 静态变量static的使用方法
  • Unity 粒子特效在UI中使用裁剪效果
  • selenium自动化测试框架——面试题整理
  • 多协议网关BL110钡铼6路RS485转MQTT协议云网关
  • SSM开发(七) MyBatis解决实体类(model)的字段名和数据库表的列名不一致方法总结(四种方法)
  • 【C语言练习题】找出不是两个数组共有的元素
  • 《深入Python子域名扫描:解锁网络空间的隐藏宝藏》
  • CPP-存储区域
  • c语言网 1127 尼科彻斯定理
  • 阅读springboot源码 记录
  • 动手学深度学习-卷积神经网络-3填充和步幅
  • Python GUI 开发 | Qt Designer — 工具介绍
  • TensorFlow 2基本功能和示例代码
  • 初阶1 入门
  • lightweight-charts-python 包 更新 lightweight-charts.js 的方法
  • EasyExcel使用详解
  • AI 编程工具—Cursor进阶使用 Rules for AI
  • AIP-132 标准方法:List
  • Bootstrap HTML编码规范
  • 【Super Tilemap Editor使用详解】(十四):工具栏菜单(Toolbar Menu)
  • gradle和maven的区别以及怎么选择使用它们
  • 【PyTorch】5.张量索引操作
  • UE求职Demo开发日志#13 完善所有伤害判定
  • 【ESP32】ESP-IDF开发 | WiFi开发 | UDP用户数据报协议 + UDP客户端和服务器例程
  • AI软件外包需要注意什么 外包开发AI软件的关键因素是什么 如何选择AI外包开发语言
  • 2025年寒假ACM训练赛1