news 2026/4/15 5:58:27

UVa 125 Numbering Paths

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
UVa 125 Numbering Paths

题目描述

本题要求计算在一个由单向街道组成的城市中,从每个交叉路口到另一个交叉路口的不同路径数量。交叉路口用非负整数标识,单向街道由一对整数j jjk kk表示,代表从j jjk kk的单向街道。若两个交叉路口之间存在无穷多条路径(即存在环路),则输出− 1 -11。输入包含多个城市的数据,每个城市以街道数量开始,随后是若干对整数表示街道。每个城市的交叉路口编号从0 00到最大编号。要求输出一个矩阵,其中M [ j ] [ k ] M[j][k]M[j][k]表示从j jjk kk的路径数,若无穷多则输出− 1 -11

题目分析

本题本质上是求有向图中任意两点间的路径数量,并处理存在环路导致路径数无穷的情况。由于交叉路口数量不超过30 3030,可以使用Floyd-Warshall \texttt{Floyd-Warshall}Floyd-Warshall算法的变种来解决。

关键点在于:

  1. 初始化矩阵m a t r i x [ i ] [ j ] = 1 matrix[i][j] = 1matrix[i][j]=1若存在从i iij jj的直接边。
  2. 使用Floyd-Warshall \texttt{Floyd-Warshall}Floyd-Warshall算法累积路径数:m a t r i x [ i ] [ j ] + = m a t r i x [ i ] [ k ] × m a t r i x [ k ] [ j ] matrix[i][j] += matrix[i][k] \times matrix[k][j]matrix[i][j]+=matrix[i][k]×matrix[k][j]
  3. 若存在环路(即m a t r i x [ k ] [ k ] > 0 matrix[k][k] > 0matrix[k][k]>0),则所有经过k kk的路径数都会变成无穷大,即设置为− 1 -11

解题思路

  1. 读入数据:对于每个城市,读入街道数量,然后读入每一条街道,更新邻接矩阵,并记录最大的交叉路口编号。
  2. Floyd-Warshall \texttt{Floyd-Warshall}Floyd-Warshall算法计算路径数
    • 第一遍三重循环:对于每个中间节点k kk,更新m a t r i x [ i ] [ j ] + = m a t r i x [ i ] [ k ] × m a t r i x [ k ] [ j ] matrix[i][j] += matrix[i][k] \times matrix[k][j]matrix[i][j]+=matrix[i][k]×matrix[k][j]。这利用了动态规划的思想,计算从i iij jj经过k kk的路径数。
    • 第二遍三重循环:检查每个节点k kk是否在环上(m a t r i x [ k ] [ k ] > 0 matrix[k][k] > 0matrix[k][k]>0)。如果是,则对于所有i iij jj,若m a t r i x [ i ] [ k ] matrix[i][k]matrix[i][k]m a t r i x [ k ] [ j ] matrix[k][j]matrix[k][j]都非零,说明从i iij jj的路径可以经过该环无限次,因此m a t r i x [ i ] [ j ] = − 1 matrix[i][j] = -1matrix[i][j]=1
  3. 输出结果:按照格式输出矩阵。

时间复杂度

Floyd-Warshall \texttt{Floyd-Warshall}Floyd-Warshall算法的时间复杂度为O ( n 3 ) O(n^3)O(n3),其中n ≤ 30 n \leq 30n30,因此完全可以在规定时间内完成。

代码实现

// Numbering Paths// UVa ID: 125// Verdict: Accepted// Submission Date: 2015-11-27// UVa Run Time: 0.000s//// 版权所有(C)2015,邱秋。metaphysis # yeah dot net#include<bits/stdc++.h>usingnamespacestd;#defineMAXV31intmatrix[MAXV][MAXV];intlargest;voidfloyd(){for(intk=0;k<=largest;k++)for(inti=0;i<=largest;i++)for(intj=0;j<=largest;j++)matrix[i][j]+=matrix[i][k]*matrix[k][j];for(intk=0;k<=largest;k++)if(matrix[k][k])for(inti=0;i<=largest;i++)for(intj=0;j<=largest;j++)if(matrix[i][k]&&matrix[k][j])matrix[i][j]=-1;}intmain(intac,char*av[]){intintersections;intcases=0;intstart,end;while(cin>>intersections){largest=0;memset(matrix,0,sizeof(matrix));for(inti=1;i<=intersections;i++){cin>>start>>end;matrix[start][end]=1;largest=max(largest,max(start,end));}floyd();cout<<"matrix for city "<<cases++<<endl;for(inti=0;i<=largest;i++){cout<<matrix[i][0];for(intj=1;j<=largest;j++)cout<<" "<<matrix[i][j];cout<<endl;}}return0;}

总结

本题通过Floyd-Warshall \texttt{Floyd-Warshall}Floyd-Warshall算法的变种,巧妙地解决了有向图中路径计数的问题,并处理了环路导致的无穷路径情况。代码简洁高效,适合作为图论中路径计数问题的经典例题。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/14 1:40:50

OpenVINO™ AI插件终极指南:打造智能音频处理工作流

OpenVINO™ AI插件终极指南&#xff1a;打造智能音频处理工作流 【免费下载链接】openvino-plugins-ai-audacity A set of AI-enabled effects, generators, and analyzers for Audacity. 项目地址: https://gitcode.com/gh_mirrors/op/openvino-plugins-ai-audacity 还…

作者头像 李华
网站建设 2026/4/10 13:14:32

BiliBili-UWP第三方客户端:Windows平台上的B站观影新体验

BiliBili-UWP第三方客户端&#xff1a;Windows平台上的B站观影新体验 【免费下载链接】BiliBili-UWP BiliBili的UWP客户端&#xff0c;当然&#xff0c;是第三方的了 项目地址: https://gitcode.com/gh_mirrors/bi/BiliBili-UWP BiliBili-UWP是一款专为Windows 10/11系统…

作者头像 李华
网站建设 2026/4/11 10:25:23

Chartero终极指南:5分钟让Zotero文献管理可视化起飞

Chartero终极指南&#xff1a;5分钟让Zotero文献管理可视化起飞 【免费下载链接】Chartero Chart in Zotero 项目地址: https://gitcode.com/gh_mirrors/ch/Chartero 还在为海量文献头疼&#xff1f;每天面对成堆的PDF文档&#xff0c;却无法直观了解自己的阅读进度和效…

作者头像 李华
网站建设 2026/4/9 21:28:04

开源许可证解读:Z-Image-Turbo可商用吗?

开源许可证解读&#xff1a;Z-Image-Turbo可商用吗&#xff1f; 阿里通义Z-Image-Turbo WebUI图像快速生成模型 二次开发构建by科哥 核心结论先行&#xff1a;Z-Image-Turbo 基于 Apache 2.0 许可证发布&#xff0c;允许商业用途、修改与分发&#xff0c;但需保留原始版权声明…

作者头像 李华
网站建设 2026/4/14 16:13:04

边缘计算实践:轻量级中文识别模型的快速部署

边缘计算实践&#xff1a;轻量级中文识别模型的快速部署 在嵌入式设备上部署中文物体识别功能时&#xff0c;工程师常常面临计算资源有限、内存占用过高和模型准确率难以平衡的挑战。本文将介绍如何利用预置的轻量级中文识别模型镜像&#xff0c;快速在边缘设备上部署高效的物体…

作者头像 李华
网站建设 2026/4/5 5:39:13

智能零售解决方案:30分钟搭建商品识别演示系统

智能零售解决方案&#xff1a;30分钟搭建商品识别演示系统 在零售科技领域&#xff0c;快速搭建商品识别演示系统是销售团队向客户展示自动货架盘点方案的关键。本文将介绍如何利用预置镜像&#xff0c;在30分钟内完成一个商品识别演示系统的搭建&#xff0c;即使你技术资源有限…

作者头像 李华