news 2026/4/16 8:33:24

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/15 18:16:37

终极指南:在PPT中完美插入LaTeX公式的完整解决方案

终极指南&#xff1a;在PPT中完美插入LaTeX公式的完整解决方案 【免费下载链接】IguanaTex A PowerPoint add-in allowing you to insert LaTeX equations into PowerPoint presentations on Windows and Mac 项目地址: https://gitcode.com/gh_mirrors/ig/IguanaTex 还…

作者头像 李华
网站建设 2026/4/16 15:52:33

1985-2025年高校专利明细数据

数据简介 在国家创新驱动发展战略与知识产权强国战略深度融合的背景下&#xff0c;高校作为科技创新的核心策源地&#xff0c;其专利产出与布局不仅是衡量科研创新实力的核心指标&#xff0c;更是推动产学研协同转化、破解“卡脖子”技术难题的关键支撑。高校专利数据所承载的…

作者头像 李华
网站建设 2026/4/16 10:53:47

Linux虚拟显示器黑科技:5分钟搞定多屏办公神器

Linux虚拟显示器黑科技&#xff1a;5分钟搞定多屏办公神器 【免费下载链接】virtual-display-linux Create virtual display / monitor on linux OS for extended display via teamviewer or vnc server without any real Monitor is Plugged In. 项目地址: https://gitcode.…

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

一键搞定网页乱码:浏览器编码优化的终极方案

一键搞定网页乱码&#xff1a;浏览器编码优化的终极方案 【免费下载链接】Chrome-Charset An extension used to modify the page default encoding for Chromium 55 based browsers. 项目地址: https://gitcode.com/gh_mirrors/ch/Chrome-Charset 还在为网页显示乱码而…

作者头像 李华
网站建设 2026/4/16 17:06:38

国家中小学智慧教育平台电子教材PDF下载工具使用手册

国家中小学智慧教育平台电子教材PDF下载工具使用手册 【免费下载链接】tchMaterial-parser 国家中小学智慧教育平台 电子课本下载工具 项目地址: https://gitcode.com/GitHub_Trending/tc/tchMaterial-parser 还在为备课需要电子教材却只能在线预览而困扰吗&#xff1f;…

作者头像 李华
网站建设 2026/4/15 21:21:44

AI视觉快速验证:云端预装环境加速产品原型开发

AI视觉快速验证&#xff1a;云端预装环境加速产品原型开发 当产品团队需要在短时间内验证AI功能的可行性时&#xff0c;从头搭建技术栈往往会耗费大量时间。本文将介绍如何利用云端预装环境快速启动AI视觉项目&#xff0c;特别适合需要在一周内完成原型验证的团队。这类任务通常…

作者头像 李华