D. Maximum Distance(最小生成树)

news2025/1/19 12:59:45

Problem - D - Codeforces

 

Chouti已经厌倦了乏味的作业,于是他打开了数年前创建的一个旧编程问题。

给定一个具有n个节点和m条加权边的连通无向图。其中有k个特殊节点:x1,x2,...,xk。

现在定义路径的成本为其边权的最大值。两个顶点之间的距离定义为连接它们的路径的最小成本。

对于每个特殊节点,请找到与其距离最远(根据上述定义,即相应距离是可能的最大值)的另一个特殊节点,并输出它们之间的距离。

由于原始限制非常小,所以他认为这个问题很无聊。现在,他提高了限制,并希望您能为他解决这个问题。

输入 第一行包含三个整数n、m和k(2≤k≤n≤105,n−1≤m≤105)——节点数、边数和特殊节点数。

第二行包含k个不同的整数x1,x2,…,xk(1≤xi≤n)。

接下来的m行,每行包含三个整数u、v和w(1≤u,v≤n,1≤w≤109),表示存在一条权值为w的边连接u和v。给定的图是无向的,因此边(u,v)可以在两个方向上使用。

图可能有多条边和自环。

保证图是连通的。

输出 第一行应包含k个整数。第i个整数是xi与离它最远的特殊节点之间的距离。

Examples

input

Copy

2 3 2
2 1
1 2 3
1 2 2
2 2 1

output

Copy

2 2 

input

Copy

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

output

Copy

3 3 3 

在第一个例子中,顶点 1 和顶点 2 之间的距离等于 2,因为它们之间有一条权重为 2 的边。因此,对于顶点 1 和顶点 2 来说,到最远节点的距离都是 2。

在第二个例子中,可以发现顶点 1 和顶点 2 之间、顶点 1 和顶点 3 之间的距离都是 3,而顶点 2 和顶点 3 之间的距离是 2。

该图可能存在多个边和自环,如第一个例子所示。

题解:
由于我们找的是特殊节点之间的最短距离,这道题比较特殊的是两点间的路径长度为,中间遍历过的最大边权值

由于题中两点距离是最小成本,相当于两点最小的路径长度,既然求的最小我们可以先利用最小生成树,把不需要的边去掉,这样一定最优

现在就变成了一棵树了,那么从任意一个特殊点开始,到其他所有特殊点,中途遍历过最长的边权,就是

离它最远的特殊节点之间的距离

这个距离对于所有特殊点,都适用

因为我们是从一个特殊点开始的,我们找的这个最长边权的两侧,肯定都有特殊点,这样两边的点都可以经过这个最长边权

#include <cstdio>
#include <cstring>
#include <algorithm>
#include<iostream>
#include<vector>
#include<set>
#include<map>
#include<cmath>
#include<queue>
using namespace std;
typedef long long ll;
#define int long long
typedef pair<int,int> PII;
int mod = 998244353;
int n,m,k;
struct node
{
	int l,r,x;
}a[100050];
int b[100050];
int f[100050];
int cmp(node a,node b)
{
	return a.x < b .x;
}
int find(int x)
{
	if(f[x] == x)
	return x;
	return f[x] = find(f[x]);
}
vector<PII> p[100050];
int d[100050];
void dfs(int x,int fa)
{
	for(PII ne:p[x])
	{
		if(ne.first == fa)
		continue;
		d[ne.first] = max(d[x],ne.second);
		dfs(ne.first,x);
	}
}
void solve()
{
	cin >> n >> m >> k;
	for(int i = 1;i <= k;i++)
	{
		cin >> b[i];
	}
	for(int i = 1;i <= m;i++)
	{
		cin >> a[i].l >> a[i].r >> a[i].x; 
	}
	for(int i = 1;i <= n;i++)
	f[i] = i; 
	sort(a + 1,a + 1 + m,cmp);
	for(int i = 1;i <= m;i++)
	{
		int x = find(a[i].l);
		int y = find(a[i].r);
		if(x != y)
		{
			f[x] = y;
			p[a[i].l].push_back({a[i].r,a[i].x});
			p[a[i].r].push_back({a[i].l,a[i].x});
		}
	}
	dfs(b[1],0);
	int ma = 0;
	for(int i = 1;i <= k;i++)
	ma = max(ma,d[b[i]]);
	for(int i = 1;i <= k;i++)
	cout << ma <<" ";
}
//5 7 8 9 10

signed main()
{
//	ios::sync_with_stdio(0);
//	cin.tie(0);cout.tie(0);
	int t = 1;
//	cin >> t;
	while(t--)
	{
		solve(); 
	}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/469576.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

从C出发 29 --- 指针与函数

只有知道具体位置&#xff0c;才有可能跳到那个位置去执行&#xff0c;如果不知道在哪里&#xff0c;怎么跳&#xff1f; 函数是什么&#xff1f; 函数就是一片连续的内存 数组是什么&#xff1f; 数组就是一片连续的内存 很显然&#xff0c;这一片连续的内存当中&#xff0c…

百度智能云六大产品系列将率先基于大模型升级,加速全面智能化

百度智能云在上海召开文心一言技术交流会。百度集团副总裁袁佛玉表示&#xff0c;大模型的技术突破&#xff0c;使得全球性的“AI再造”已经拉开序幕。在技术底座层面&#xff0c;百度智能云拥有全栈自研的AI大底座&#xff1b;在大模型平台层面&#xff0c;拥有全球首个一站式…

OSGI详解

最近项目用到了OSGI&#xff0c;第一反应就是什么是OSGI&#xff1f; OSGI是一个为Java提供动态模块化的系统&#xff1b; 准确的说&#xff0c;OSGI是一个标准&#xff0c;一个框架&#xff0c;也可以理解为一个容器&#xff0c;具体的实现有Eclipse下的Equinox和Appach下的Fe…

18. Unity - 2D游戏开发小记01 --- 瓦片地图搭建基本操作

1. 瓦片地图创建(Tilemap) 在2D游戏开发中,瓦片地图就是游戏中的场景或者说游戏背景,可以使用把图片资源制作成Tiles,然后在游戏场景中搭建2D游戏的背景即可。 效果展示: 规则瓦片制作 首先在 Hierarchy层级窗口中右键鼠标,依次选择 2D Object → Tilemap → Rectan…

SpirngMVC的创建和使用

SpirngMVC的创建 SpringMVC的创建很容易。 步骤&#xff1a;创建SpringBoot项目&#xff0c;并在添加依赖时&#xff0c;添加Spring Web。 SpringMVC的创建就完成了。 创建SpringBoot项目详情&#xff1a;SpringBoot项目创建和使用_追梦不止&#xff5e;的博客-CSDN博客 S…

lua元表、元方法

lua元表、元方法 lua官方参考手册&#xff1a;https://www.runoob.com/manual/lua53doc/manual.html#2.4 一、总结&#xff1a; ☺ 1、普通的表&#xff0c;找不到了&#xff0c;或者无法进行运算的时候&#xff0c;考虑设置到它身上的元表的元方法 2、元表的本质&#xff1a…

JavaWeb03(域对象EL表达式JSTL标签)

目录 一.jsp内置对象之域对象 1.1 什么是jsp的内置对象? JSP的内置对象是指在JSP页面系统中已经默认内置的Java对象&#xff0c;这些对象不需要开发人员显式声明即可使用。一共有9个&#xff1a; 分别为request、response、session、application、out、pageContext、confi…

netfilter filter表(三)

修改《netfilter filter表(二)》的hello_open函数&#xff0c;将ipt_entry的信息打印处理&#xff0c;代码如下&#xff1a; char* get_verdict(int verdict) {verdict -(verdict 1);char* p "";switch (verdict){case NF_DROP:p "NF_DROP";break;cas…

【LeetCode训练营】反转链表 移除链表元素 详细图解 203,206

&#x1f48c; 博客内容&#xff1a;LeetCode 训练营 &#x1f600; 作  者&#xff1a;陈大大陈 &#x1f680; 个人简介&#xff1a;一个正在努力学技术的准前端&#xff0c;专注基础和实战分享 &#xff0c;欢迎私信&#xff01; &#x1f496; 欢迎大家&#xff1a;这…

SpringMVC实现文件上传和下载和Json的简单实用

目录 SpringMVC实现文件上传和下载 1、文件下载 2、文件上传 &#xff08;1&#xff09;文件上传操作的分析 &#xff08;2&#xff09;实现步骤 (3&#xff09;解决文件重名覆盖问题 Json的简单使用 1、Json概述 2、Json的语法格式 3、Jackson的QuickStart SpringMVC…

【C++STL】map

文章目录 一. map的介绍二. map的使用结束语 一. map的介绍 map是关联容器&#xff0c;它按照特定的次序&#xff08;按照key来比较&#xff09;存储由键值key和值value组合而成的元素在map中&#xff0c;键值key通常用于排序和唯一地标识元素&#xff0c;而value中存储与此键值…

OSI七层模型、TCP/IP四层模型

OSI七层模型和TCP/IP四层模型 OSI七层模型 物理层&#xff1a;底层数据传输&#xff0c;如网线、网卡标准数据链路层&#xff1a;定义数据基本格式&#xff0c;如何传输如何标识&#xff1b;如网卡MAC地址网络层&#xff1a;定义IP地址&#xff0c;定义路由功能&#xff1b;如…

【中级软件设计师】—(针对上午题)二十三种设计模式(三十九)

【中级软件设计师】—&#xff08;针对上午题&#xff09;二十三种设计模式&#xff08;三十九&#xff09; 一、设计模式的分类 背背背 1 二、创建型设计模式&#xff08;5种&#xff09; 三、简单工厂模式 简单工厂模式代码实现如下&#xff1a; /*** author&#xff1a;Ca…

CentOS分区挂载 fdisk、parted方式解析

1 介绍 在linux中&#xff0c;通常会将持久化数据保存到硬盘当中&#xff0c;但是硬盘一把会比较大&#xff0c;因此我们为了方便管理&#xff0c;会将一个硬盘分成多个逻辑硬盘&#xff0c;称之为分区。 为了能够让分区中的文件使得能让操作系统处理&#xff0c;则需要对分区…

Java阶段二Day11

Java阶段二Day11 文章目录 Java阶段二Day11DQL主键与外键外键约束多对多关系内连接外连接自连接 JDBC核心接口JDBC连接的基本流程 教师总结主键与外键外键约束结论:关联关系中通常不适用外键约束。 多对多关系多对多关联查询例 练习题干答案 内连接语法例 外连接例 自连接定义场…

研报精选230427

目录 【行业230427东方金诚】有色金属行业信用风险回顾与2023年展望 【行业230427头豹研究院】2023年中国汽车安全气囊行业词条报告 【行业230427头豹研究院】2023年中国钠离子负极材料行业词条报告 【个股230427开源证券_佳禾食品】公司首次覆盖报告&#xff1a;植脂末龙头再启…

小匠物联出席宁波第五届家电产业数字化对接会助推家电产业数智化

宁波的家电资源与市场充足&#xff0c;特别是小家电&#xff0c;涉及20多个细分行业、近千个品种&#xff0c;其中10多个细分行业小家电产量一直位居全国或全球首列。但受原材料上涨等多重因素的影响&#xff0c;作为宁波市传统优势产业的家电产业也未能避免&#xff0c;产业数…

ldif 数据转成正确的组织结构再探

上次文章最后有说到按照之前的思路来转化组织结构是有坑的&#xff0c;我们现在还只是对接 AD域&#xff0c;ldap 协议的其他产品在细节上还会有些许不同 我们是不能直接粗暴的认为 cn 就是对应标识一个用户&#xff0c; cn 是 common name 的意思&#xff0c;他也可以表示我们…

【LeetCode】(力扣) c/c++刷题-145. 二叉树的后序遍历

题目&#xff1a; 给你一棵二叉树的根节点 root &#xff0c;返回其节点值的 后序遍历 。 示例 1&#xff1a; 输入&#xff1a;root [1,null,2,3] 输出&#xff1a;[3,2,1] 示例 2&#xff1a; 输入&#xff1a;root [] 输出&#xff1a;[] 示例 3&#xff1a; 输入&a…

线性表的链式存储结构与操作 题目编号:455

题目描述 评论 请你定义一个链表&#xff0c;可以对链表进行“在某个元素之前插入一些元素”、“删除某个位置的元素”、“查找某元素”、“获取某个位置的元素”、“遍历输出所有元素”、“求链表的长度”等操作。键盘输入一些命令&#xff0c;可以执行上述操作。本题中&…