shuoj-小6爱夜跑--Floyd记录多个最短路径

2023-12-22 17:32

本文主要是介绍shuoj-小6爱夜跑--Floyd记录多个最短路径,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Description

自从小6学了最短路算法之后,就成了一个不折不扣的最短路理论拥护者,每次在校园里夜跑的时候,只要确定好起点和终点他就能快速算出最短的路径。然而小6却没有走过每一条路,只是对这些路径长度做了一个粗略估计,于是每条路就有了估计值与实际值的差距。小6想要知道从起点到终点,按照其中任意一条预估的最短路径跑,实际最长可能需要走过的路程。(因为同一长度的最短路可能有多个)

Input

多组输入,第一行是一个整数T,表示输入数据的组数(T≤20)。

接下来有T组数据,每组数据的第一行是四个整数N、M、S、E,分别代表图中的顶点数、边数、起点编号和终点编号。

(2N100, 1M1000, 1S,TN, ST)

之后的M行每行有四个整数u, v, a, b,代表图中编号为u的点到编号为v的点有一条双向边。

每条边有两个值a、b分别代表这条边的估计长度与实际长度。

(1u,vN, 1a,b1000, u ≠ v)

数据保证两个顶点间至多只有一条双向边相连,起点与终点间必定存在通路。

Output

对于每组输入,输出一行两个整数并换行,表示小6估算出的最短路长度以及实际最长可能需要走过的路程,两个整数间有一个空格。

Sample Input

22 1 1 21 2 3 43 3 1 31 2 2 31 3 3 42 3 1 2

Sample Output

3 43 5


题意::有一个图,图有两层,通过第一层的数据求所有的最短路。然后用第二层的权值计算第一层求得的最短路的最大权值。
刚开始看这道题就想到了记录路径的方式,但是究竟如何把多个路径记录下来呢?这里的确遇到了问题。在这里给出了用Floyd记录多重路径的 方法。


题解::

1)假设c【A】【B】数组中存放A,B两点的最短路,我们知道如果在c【A】【B】 == c【A】【C】+c【C】【B】,那么(A->C->B)也是一条最短路。所以我们可以用二维的vector记录中间节点C,既path【A】【B】.push_back(C)。

2)Floyd算法更新节点是在c【A】【B】 > c【A】【C】+c【C】【B】的时候。同样的如果满足该条件,那么path【A】【B】中存放的都将不是最短路,要进行clear()操作。

3)我们知道如果从A点到B点有N种最短路径,B点到C点有M种最短路径,那么从A经过B到C共有N*M种最短路径。(计算最短路有多少条)。

当把最短路都记录下来后还有一个问题,如何根据最短路求题中要求的最长路。

1)如果path【A】【B】为 空,那最长路肯定是d【A】【B】
2)如果path【A】【B】不为空,
        1)假如有一条最短路A->C->B就分别求A C之间最长路,和B C之间的最长路。分别放入d【A】【C】,d【C】【B】。
2)比较d【A】【B】与d【A】【C】+d【C】【B】的大小。既d【A】【B】 = d【A】【B】>d【A】【C】+d【C】【B】? d【A】【B】:d【A】【C】+d【C】 【B】(C可能有多个。)
(用递归实现)


思路在经过细分析后也不是很难,哈哈哈。
代码如下:


#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int INF = 0x3f3f3f3f;
vector<ll> path[120][120];ll c[120][120];
ll d[120][120];
ll max_load(int x,int y){if(path[x][y].empty())return d[x][y];for(int i = 0;i<path[x][y].size();i++){ll ans = path[x][y][i];return max(d[x][y],max_load(ans,y)+max_load(x,ans));}
}
int main(){int T;cin>>T;while(T--){for(int i = 0;i<120;i++)for(int j = 0;j<120;j++)path[i][j].clear();int m,n,s,e;cin>>n>>m>>s>>e;int u,v,a,b;for(int i = 0;i<n;i++)for(int j = 0;j<n;j++)c[i][j] = 2000;for(int i = 0;i<n;i++)c[i][i] = 0;for(int i = 0;i<m;i++){cin>>u>>v>>a>>b;u--;v--;c[u][v] = a;c[v][u] = a;d[u][v] = b;d[v][u] = b;}for (int k =0 ; k< n; k++){for (int i = 0; i< n; i++){for (int j = 0; j< n; j++)if (c[i][j] > c[i][k] + c[k][j]){c[i][j] = c[i][k]+c[k][j];path[i][j].clear();path[i][j].push_back(k);}else if (c[i][j] == c[i][k] + c[k][j] && k!= i &&k !=j)path[i][j].push_back(k);}}cout<<c[s-1][e-1]<<" ";cout<<max_load(s-1,e-1)<<endl;}return 0;
}
谢谢!











这篇关于shuoj-小6爱夜跑--Floyd记录多个最短路径的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

linux下多个硬盘划分到同一挂载点问题

《linux下多个硬盘划分到同一挂载点问题》在Linux系统中,将多个硬盘划分到同一挂载点需要通过逻辑卷管理(LVM)来实现,首先,需要将物理存储设备(如硬盘分区)创建为物理卷,然后,将这些物理卷组成... 目录linux下多个硬盘划分到同一挂载点需要明确的几个概念硬盘插上默认的是非lvm总结Linux下多

关于Spring @Bean 相同加载顺序不同结果不同的问题记录

《关于Spring@Bean相同加载顺序不同结果不同的问题记录》本文主要探讨了在Spring5.1.3.RELEASE版本下,当有两个全注解类定义相同类型的Bean时,由于加载顺序不同,最终生成的... 目录问题说明测试输出1测试输出2@Bean注解的BeanDefiChina编程nition加入时机总结问题说明

mysqld_multi在Linux服务器上运行多个MySQL实例

《mysqld_multi在Linux服务器上运行多个MySQL实例》在Linux系统上使用mysqld_multi来启动和管理多个MySQL实例是一种常见的做法,这种方式允许你在同一台机器上运行多个... 目录1. 安装mysql2. 配置文件示例配置文件3. 创建数据目录4. 启动和管理实例启动所有实例

将sqlserver数据迁移到mysql的详细步骤记录

《将sqlserver数据迁移到mysql的详细步骤记录》:本文主要介绍将SQLServer数据迁移到MySQL的步骤,包括导出数据、转换数据格式和导入数据,通过示例和工具说明,帮助大家顺利完成... 目录前言一、导出SQL Server 数据二、转换数据格式为mysql兼容格式三、导入数据到MySQL数据

关于rpc长连接与短连接的思考记录

《关于rpc长连接与短连接的思考记录》文章总结了RPC项目中长连接和短连接的处理方式,包括RPC和HTTP的长连接与短连接的区别、TCP的保活机制、客户端与服务器的连接模式及其利弊分析,文章强调了在实... 目录rpc项目中的长连接与短连接的思考什么是rpc项目中的长连接和短连接与tcp和http的长连接短

Oracle查询优化之高效实现仅查询前10条记录的方法与实践

《Oracle查询优化之高效实现仅查询前10条记录的方法与实践》:本文主要介绍Oracle查询优化之高效实现仅查询前10条记录的相关资料,包括使用ROWNUM、ROW_NUMBER()函数、FET... 目录1. 使用 ROWNUM 查询2. 使用 ROW_NUMBER() 函数3. 使用 FETCH FI

Python MySQL如何通过Binlog获取变更记录恢复数据

《PythonMySQL如何通过Binlog获取变更记录恢复数据》本文介绍了如何使用Python和pymysqlreplication库通过MySQL的二进制日志(Binlog)获取数据库的变更记录... 目录python mysql通过Binlog获取变更记录恢复数据1.安装pymysqlreplicat

使用SQL语言查询多个Excel表格的操作方法

《使用SQL语言查询多个Excel表格的操作方法》本文介绍了如何使用SQL语言查询多个Excel表格,通过将所有Excel表格放入一个.xlsx文件中,并使用pandas和pandasql库进行读取和... 目录如何用SQL语言查询多个Excel表格如何使用sql查询excel内容1. 简介2. 实现思路3

Servlet中配置和使用过滤器的步骤记录

《Servlet中配置和使用过滤器的步骤记录》:本文主要介绍在Servlet中配置和使用过滤器的方法,包括创建过滤器类、配置过滤器以及在Web应用中使用过滤器等步骤,文中通过代码介绍的非常详细,需... 目录创建过滤器类配置过滤器使用过滤器总结在Servlet中配置和使用过滤器主要包括创建过滤器类、配置过滤

python获取当前文件和目录路径的方法详解

《python获取当前文件和目录路径的方法详解》:本文主要介绍Python中获取当前文件路径和目录的方法,包括使用__file__关键字、os.path.abspath、os.path.realp... 目录1、获取当前文件路径2、获取当前文件所在目录3、os.path.abspath和os.path.re