bzoj2180: 最小直径生成树

2024-04-02 10:32
文章标签 最小 生成 直径 bzoj2180

本文主要是介绍bzoj2180: 最小直径生成树,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=2180

思路:先枚举图的绝对中心在哪条边(u,v)上,绝对中心就是到最远点的距离最近的点,可以在边上

设绝对中心到该边一个端点的距离为x

然后每个图中的s点到它的距离就会是关于x的函数 即min(dis[u][s]+x,dis[v][s]+L-x)

这是一条折线,那么每个点到它的距离都会是一条折线

那么,我们就要使两个距离最大点的取值最小

就是所有折线的最上面构成的折线的最下面的点

说的有些复杂,可以看这个博客

http://blog.csdn.net/crazy_ac/article/details/8816877

按d[u][i]从大到小排序一遍扫描即可


#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
const int maxn=205,maxm=50010;
using namespace std;
int n,m,d[maxn][maxn],inf,tot,rank[maxn][maxn],ans=(int)1e9;
struct Edge{int x,y,v;}E[maxm];
void floyd(){for (int k=1;k<=n;k++)for (int i=1;i<=n;i++) if (i!=k)for (int j=1;j<=n;j++) if (i!=j&&k!=j)d[i][j]=min(d[i][j],d[i][k]+d[k][j]);
}void work(int id){int u=E[id].x,v=E[id].y,L=E[id].v;for (int a=1,b=2;b<=n;b++){if (d[v][rank[u][a]]>d[v][rank[u][b]]) continue;ans=min(ans,d[v][rank[u][a]]+d[u][rank[u][b]]+L);a=b;}
}int main(){scanf("%d%d",&n,&m),memset(d,63,sizeof(d)),inf=d[0][0];for (int i=1;i<=n;i++) d[i][i]=0;for (int i=1,x,y,z;i<=m;i++) scanf("%d%d%d",&x,&y,&z),d[x][y]=d[y][x]=min(d[x][y],z);//for (int i=1;i<=n;i++,puts("")) for (int j=1;j<=n;j++) printf("%d ",d[i][j]);for (int i=1;i<=n;i++) for (int j=1;j<i;j++) if (d[i][j]!=inf) E[++tot]=(Edge){j,i,d[i][j]};floyd();for (int i=1;i<=n;i++) for (int j=1;j<=n;j++) rank[i][j]=j;for (int i=1;i<=n;i++)for (int j=1;j<=n;j++)for (int k=j+1;k<=n;k++)if (d[i][rank[i][j]]<d[i][rank[i][k]]) swap(rank[i][j],rank[i][k]);for (int i=1;i<=n;i++) ans=min(ans,d[i][rank[i][1]]+d[i][rank[i][2]]);for (int i=1;i<=tot;i++) work(i);printf("%d\n",ans);return 0;
}/*
8 11
1 3 1
1 2 2
2 4 3
2 6 7
4 6 0
6 8 4
8 7 3
7 5 1
6 3 5
7 3 5
5 3 6
*/


这篇关于bzoj2180: 最小直径生成树的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/869736

相关文章

详解Java中如何使用JFreeChart生成甘特图

《详解Java中如何使用JFreeChart生成甘特图》甘特图是一种流行的项目管理工具,用于显示项目的进度和任务分配,在Java开发中,JFreeChart是一个强大的开源图表库,能够生成各种类型的图... 目录引言一、JFreeChart简介二、准备工作三、创建甘特图1. 定义数据集2. 创建甘特图3.

AI一键生成 PPT

AI一键生成 PPT 操作步骤 作为一名打工人,是不是经常需要制作各种PPT来分享我的生活和想法。但是,你们知道,有时候灵感来了,时间却不够用了!😩直到我发现了Kimi AI——一个能够自动生成PPT的神奇助手!🌟 什么是Kimi? 一款月之暗面科技有限公司开发的AI办公工具,帮助用户快速生成高质量的演示文稿。 无论你是职场人士、学生还是教师,Kimi都能够为你的办公文

zoj3820(树的直径的应用)

题意:在一颗树上找两个点,使得所有点到选择与其更近的一个点的距离的最大值最小。 思路:如果是选择一个点的话,那么点就是直径的中点。现在考虑两个点的情况,先求树的直径,再把直径最中间的边去掉,再求剩下的两个子树中直径的中点。 代码如下: #include <stdio.h>#include <string.h>#include <algorithm>#include <map>#

pdfmake生成pdf的使用

实际项目中有时会有根据填写的表单数据或者其他格式的数据,将数据自动填充到pdf文件中根据固定模板生成pdf文件的需求 文章目录 利用pdfmake生成pdf文件1.下载安装pdfmake第三方包2.封装生成pdf文件的共用配置3.生成pdf文件的文件模板内容4.调用方法生成pdf 利用pdfmake生成pdf文件 1.下载安装pdfmake第三方包 npm i pdfma

poj 1258 Agri-Net(最小生成树模板代码)

感觉用这题来当模板更适合。 题意就是给你邻接矩阵求最小生成树啦。~ prim代码:效率很高。172k...0ms。 #include<stdio.h>#include<algorithm>using namespace std;const int MaxN = 101;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int n

poj 1287 Networking(prim or kruscal最小生成树)

题意给你点与点间距离,求最小生成树。 注意点是,两点之间可能有不同的路,输入的时候选择最小的,和之前有道最短路WA的题目类似。 prim代码: #include<stdio.h>const int MaxN = 51;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int P;int prim(){bool vis[MaxN];

poj 2349 Arctic Network uva 10369(prim or kruscal最小生成树)

题目很麻烦,因为不熟悉最小生成树的算法调试了好久。 感觉网上的题目解释都没说得很清楚,不适合新手。自己写一个。 题意:给你点的坐标,然后两点间可以有两种方式来通信:第一种是卫星通信,第二种是无线电通信。 卫星通信:任何两个有卫星频道的点间都可以直接建立连接,与点间的距离无关; 无线电通信:两个点之间的距离不能超过D,无线电收发器的功率越大,D越大,越昂贵。 计算无线电收发器D

poj 1734 (floyd求最小环并打印路径)

题意: 求图中的一个最小环,并打印路径。 解析: ans 保存最小环长度。 一直wa,最后终于找到原因,inf开太大爆掉了。。。 虽然0x3f3f3f3f用memset好用,但是还是有局限性。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#incl

hdu 1102 uva 10397(最小生成树prim)

hdu 1102: 题意: 给一个邻接矩阵,给一些村庄间已经修的路,问最小生成树。 解析: 把已经修的路的权值改为0,套个prim()。 注意prim 最外层循坏为n-1。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstri

【生成模型系列(初级)】嵌入(Embedding)方程——自然语言处理的数学灵魂【通俗理解】

【通俗理解】嵌入(Embedding)方程——自然语言处理的数学灵魂 关键词提炼 #嵌入方程 #自然语言处理 #词向量 #机器学习 #神经网络 #向量空间模型 #Siri #Google翻译 #AlexNet 第一节:嵌入方程的类比与核心概念【尽可能通俗】 嵌入方程可以被看作是自然语言处理中的“翻译机”,它将文本中的单词或短语转换成计算机能够理解的数学形式,即向量。 正如翻译机将一种语言