【算法】牛的旅行(图的直径,floyd算法求最短路)

题目

        农民John的农场里有很多牧区,有的路径连接一些特定的牧区。

        一片所有连通的牧区称为一个牧场。

        但是就目前而言,你能看到至少有两个牧区不连通。

        现在,John想在农场里添加一条路径(注意,恰好一条)。

        一个牧场的直径就是牧场中最远的两个牧区的距离(本题中所提到的所有距离指的都是最短的距离)。

        考虑如下的两个牧场,每一个牧区都有自己的坐标:

1.png

        图 1 是有 5 个牧区的牧场,牧区用“*”表示,路径用直线表示。

        图 1 所示的牧场的直径大约是 12.07106, 最远的两个牧区是 A 和 E,它们之间的最短路径是 A-B-E。

        图 2 是另一个牧场。

        这两个牧场都在John的农场上。

        John将会在两个牧场中各选一个牧区,然后用一条路径连起来,使得连通后这个新的更大的牧场有最小的直径。

        注意,如果两条路径中途相交,我们不认为它们是连通的。

        只有两条路径在同一个牧区相交,我们才认为它们是连通的。

        现在请你编程找出一条连接两个不同牧场的路径,使得连上这条路径后,所有牧场(生成的新牧场和原有牧场)中直径最大的牧场的直径尽可能小。

        输出这个直径最小可能值。

输入格式

        第 1 行:一个整数 N, 表示牧区数;

        第 2 到 N+1 行:每行两个整数 X,Y, 表示 N 个牧区的坐标。每个牧区的坐标都是不一样的。

        第 N+2 行到第 2*N+1 行:每行包括 N 个数字 ( 0或1 ) 表示一个对称邻接矩阵。

        例如,题目描述中的两个牧场的矩阵描述如下:

样例:
  A B C D E F G H 
A 0 1 0 0 0 0 0 0 
B 1 0 1 1 1 0 0 0 
C 0 1 0 0 1 0 0 0 
D 0 1 0 0 1 0 0 0 
E 0 1 1 1 0 0 0 0 
F 0 0 0 0 0 0 1 0 
G 0 0 0 0 0 1 0 1 
H 0 0 0 0 0 0 1 0

        输入数据中至少包括两个不连通的牧区。

输出格式

        只有一行,包括一个实数,表示所求答案。

        数字保留六位小数。

数据范围

        1 ≤ N ≤ 150
        0≤ X , Y ≤ 10^5

思路

        1、先将数据存储起来

        2、初始化点到点的距离

        3、使用floyd算法算出点到点的最小距离

        4、保留所有点到点 i 的最大距离,储存到maxd[]数组中。

        5、遍历maxd[]数组,距离最大的值就是所有连通图直径中的最大值,使用res1储存。

        6、遍历所有点到点的距离,如果距离大于或等于INF则表明这两个点不在同一个连通图内,将这两个点连接起来,得到的直径为maxd[ i ] + maxd[ j ] + get_dist(q[ i ],q[ j ]);如果小于res2则更新res2。

        7、输出res1与res2中的最小值。

代码

#include<bits/stdc++.h>
#define x first
#define y second
using namespace std;

typedef pair<int,int> PII;

const int N = 150;
const double INF = 1e20;

int n;// n代表牧区数目
PII q[N];// 用来储存牧区的坐标
char g[N][N];// 用来储存邻接矩阵(g[i][j] == '1' 代表点i到点j是连通的,否则代表不连通)
double d[N][N],maxd[N];// d[i][j]代表点i到点j的最小距离,maxd[i]代表所有能到达点i的最小距离中的最大距离

double get_dist(PII a,PII b)//求点a到点b的距离
{
    double dx = a.x - b.x, dy = a.y - b.y;
    return sqrt(dx * dx + dy * dy);
}

int main()
{
    cin >> n;// 输入牧区数量
    for(int i = 0; i < n; i ++) cin >> q[i].x >> q[i].y;// 依次输入牧区坐标

    for(int i = 0; i < n; i ++) cin >> g[i];// 输入邻接矩阵

    for(int i = 0; i < n; i ++)
        for(int j = 0; j < n; j ++)
            if(i != j)
            {
                if(g[i][j] == '1') d[i][j] = get_dist(q[i],q[j]);// 初始化点i到点j的距离
                else d[i][j] = INF;
            }

    for(int k = 0; k < n; k ++)
        for(int i = 0; i < n; i ++)
            for(int j = 0; j < n; j ++)
                d[i][j] = min(d[i][j],d[i][k] + d[k][j]);// 使用floyd算法求多源汇最短路(任意点到任意点的最短距离)

    for(int i = 0; i < n; i ++)
        for(int j = 0; j < n; j ++)
            if(d[i][j] < INF)
                maxd[i] = max(maxd[i],d[i][j]);// 求出所有能到达点i的最小距离中的最大距离

    double res1 = 0;
    for(int i = 0; i < n; i ++) res1 = max(res1,maxd[i]);// 使用res1储存所有连通图中直径的最大的值

    double res2 = INF;
    for(int i = 0; i < n; i ++)
        for(int j = 0; j < n; j ++)
            if(d[i][j] >= INF)
                res2 = min(res2,get_dist(q[i],q[j]) + maxd[i] + maxd[j]);// 使用res2储存连接一条边之后所得到新的连通图的直径的最小值

    printf("%lf\n",max(res1,res2));

    return 0;

}

题目来自网站:https://www.acwing.com/

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

基于JavaWeb+SSM+Vue校内校园二手交易微信小程序系统的设计和实现

基于JavaWebSSMVue校内校园二手交易微信小程序系统的设计和实现 源码传送入口前言主要技术系统设计功能截图Lun文目录订阅经典源码专栏Java项目精品实战案例《500套》 源码获取 源码传送入口 前言 在Internet高速发展的今天&#xff0c;我们生活的各个领域都涉及到计算机的应…

vmware配置固定ip

1.在vmware中选择编辑-->虚拟网络编辑器。 1.1按下面1&#xff0c;2&#xff0c;3顺序操作&#xff0c;分别修改子网IP:192.168.5.0&#xff0c;子网掩码:255.255.255.0,这里的子网ip为什么是192.168.5.0呢&#xff0c;因为物理机器的关网是192.168.5.1&#xff0c;见物理机…

creo6.0教程之拉伸

目录 一、实体拉伸&#xff1a;1.拉伸基本操作&#xff1a;2.其他常用的拉伸选项&#xff1a;3.移除材料的拉伸&#xff1a; 一、实体拉伸&#xff1a; 1.拉伸基本操作&#xff1a; 1、点击-拉伸&#xff0c;进入拉伸操作界面 2、选择绘制草图放置的平面&#xff0c;选择放置…

回收站清空了怎么恢复?数据恢复的 6 种方法

众所周知&#xff0c;计算机中的回收站是一个存储空间&#xff0c;用于存储从计算机系统中删除的所有文件、文件夹或数据。它是大多数计算机系统&#xff08;包括Windows、Mac等&#xff09;上的必备功能。当从计算机中删除文件或文件夹时&#xff0c;它会在回收站中存储指定的…

最全面的软考架构师复习资料(历时2年整理)

一、面向服务的架构 1.请分别用200字以内文字说明什么是面向服务架构&#xff08;SOA&#xff09;以及ESB在SOA的作用与特点 面向服务的体系架构&#xff08;SOA&#xff09;是一种粗粒度、松耦合的服务架构&#xff0c;服务之间通过简单、精确定义接口进行通信。他可以根据需求…

C/C++ 动态内存管理(内存是如何分布的?malloc/new,free/delete的用法是什么?区别是什么?)

目录 一、前言 二、C/C中的内存分布 &#x1f4a6;了解内存区域的划分 &#x1f4a6;内存存储区域的对比和注意点 &#x1f4a6;内存管理的常考面试题 三、C语言的动态管理方式 四、C的动态管理方式 &#x1f4a6;new / delete 操作内置类型&#xff08;int,char.....&…

体验前所未有的显示器管理体验:BetterDisplay Pro Mac

在现代的数字化时代&#xff0c;显示器是我们日常生活和工作中不可或缺的一部分。从笔记本电脑到台式机&#xff0c;从平板电脑到手机&#xff0c;几乎所有的电子设备都配备了显示器。然而&#xff0c;对于专业人士和从事设计行业的人来说&#xff0c;仅仅依靠系统自带的显示器…

韦东山老师的从0写RTOS笔记

生产bin文件 fromelf --bin --outputled.bin Objects\led_c.axf 生产汇编文件 fromelf --text -a -c --outputled.dis Objects\led_c.axf 1.AAPCS函数调用规则 R0-R3&#xff1a;传递参数R0&#xff1a;传递返回值SP&#xff08;R13&#xff09;&#xff1a;栈指针LR&#xff…

【算法|二分查找No.6】leetcode 153. 寻找旋转排序数组中的最小值

个人主页&#xff1a;兜里有颗棉花糖 欢迎 点赞&#x1f44d; 收藏✨ 留言✉ 加关注&#x1f493;本文由 兜里有颗棉花糖 原创 收录于专栏【手撕算法系列专栏】【LeetCode】 &#x1f354;本专栏旨在提高自己算法能力的同时&#xff0c;记录一下自己的学习过程&#xff0c;希望…

用excel计算行列式的值

例如&#xff0c;我们要计算下面这个3*3矩阵的行列式的值&#xff1a; 127348569 鼠标点到其它空白的地方&#xff0c;用来存放计算后的结果&#xff1a; 插入-》函数&#xff1a; 选择MDETERM函数&#xff0c;这个就是计算行列式的函数&#xff1a; 点击“继续”&#xff1a…

软件开发流程

目录 1 软件开发流程 第1阶段&#xff1a;需求分析 第2阶段&#xff1a;设计 第3阶段&#xff1a;编码 第4阶段&#xff1a;测试 第5阶段&#xff1a;上线运维 2 角色分工 3 软件环境 1). 开发环境(development) 2). 测试环境(testing) 3). 生产环境(production) &a…

MySQL最新2023年面试题及答案,汇总版(5)【MySQL最新2023年面试题及答案,汇总版-第三十五刊】

文章目录 MySQL最新2023年面试题及答案&#xff0c;汇总版(5)01、对MySQL的锁了解吗&#xff1f;02、MySQL中有哪几种锁&#xff1f;03、如何删除索引&#xff1f;04、索引能干什么?05、MySql, Oracle&#xff0c;Sql Service的区别&#xff1f;06、varchar与char的区别&#…

Longhorn跨AZ实现存储高可用

Longhorn跨AZ实现存储高可用 longhorn基础组件功能及其作用这里就不做介绍了 方案一 Longhorn跨AZ的高可用的就是一个PVC的replicas 均匀打散的不同的AZ区域之间&#xff0c;这样当某个AZ挂掉后&#xff0c;engine会立即使用另外一个数据副本&#xff0c;并重建这个副本&…

Rust图形界面egui初步

文章目录 下载和演示配置文件源代码 下载和演示 首先下载其源代码egui&#xff0c;然后进入其example文件夹&#xff0c;进入之后&#xff0c;使用cargo命令进行编译 cargo run --release -p hello_worldrust会自动下载一些相关的包和库&#xff0c;编译运行后&#xff0c;结…

【已解决】ModuleNotFoundError: No module named ‘sklearn‘

问题描述 Traceback (most recent call last): File "/home/visionx/nickle/temp/SimCLR/linear_evaluation.py", line 210, in <module> from sklearn.manifold import TSNE ModuleNotFoundError: No module named sklearn 解决办法 pip install numpy…

细数Leetcode上的背包问题

1 推荐刷题集合 2 lc 416. 分割等和子集 public boolean canPartition(int[] nums) {int nnums.length;int s0;for(int i0;i<n;i){snums[i];}if(s%21){return false;}boolean[]fnew boolean[s/21];f[0]true;for(int i0;i<n;i){for(int js/2;j>nums[i];j--){f[j]f[j]||…

Java TreeMap

TreeMap 是一个基于 key 有序的 key value 散列表。 map 根据其键的自然顺序排序&#xff0c;或者根据 map 创建时提供的 Comparator 排序不是线程安全的key 不可以存入null底层是基于红黑树实现的 TreeMap 的类结构图&#xff1a; 实现了 NavigableMap 接口&#xff0c;Na…

我在Vscode学OpenCV 色彩空间转换

文章目录 色彩【 1 】色彩空间&#xff08;色域&#xff09;&#xff08;1&#xff09;**RGB色彩空间**与xyz色彩空间的转换将 RGB 色彩空间转换为 XYZ 色彩空间将 XYZ 色彩空间转换为 RGB 色彩空间 &#xff08;2&#xff09;**CMYK色彩空间**&#xff08;3&#xff09;**HSV*…

这就是!Python的魅力!

文章目录 前言什么是pythonpython的由来我们为什么要学习python帮助python学习的网站总结 前言 各位朋友们&#xff0c;大家好。龙叔我后台经常收到私信问什么是Python&#xff1f;有必要学习这门语言么&#xff1f;今天&#xff0c;将通过本文告知大家Python是什么&#xf…