news 2026/1/22 12:10:33

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/1/20 7:24:34

B站CC字幕高效提取与格式转换实战指南

B站CC字幕高效提取与格式转换实战指南 【免费下载链接】BiliBiliCCSubtitle 一个用于下载B站(哔哩哔哩)CC字幕及转换的工具; 项目地址: https://gitcode.com/gh_mirrors/bi/BiliBiliCCSubtitle 你是否曾经因为无法保存B站视频的字幕而感到困扰&#xff1f;那些精彩的教学…

作者头像 李华
网站建设 2026/1/21 21:24:47

Windows APK安装器:在电脑上轻松安装安卓应用

Windows APK安装器&#xff1a;在电脑上轻松安装安卓应用 【免费下载链接】APK-Installer An Android Application Installer for Windows 项目地址: https://gitcode.com/GitHub_Trending/ap/APK-Installer 想要在Windows电脑上直接安装Android应用吗&#xff1f;这款专…

作者头像 李华
网站建设 2026/1/22 10:46:40

35个PowerBI模板实战秘籍:从报表小白到设计高手的完美蜕变

35个PowerBI模板实战秘籍&#xff1a;从报表小白到设计高手的完美蜕变 【免费下载链接】PowerBI-ThemeTemplates Snippets for assembling Power BI Themes 项目地址: https://gitcode.com/gh_mirrors/po/PowerBI-ThemeTemplates 还在为PowerBI报表的"土味设计&quo…

作者头像 李华
网站建设 2026/1/15 22:41:02

玩转MGeo地址相似度:无需本地GPU的完整教程

玩转MGeo地址相似度&#xff1a;无需本地GPU的完整教程 地址相似度计算是地理信息处理中的核心任务之一&#xff0c;广泛应用于物流分单、地址标准化、POI匹配等场景。MGeo作为阿里巴巴开源的地址大模型&#xff0c;能够高效处理中文地址的语义理解和相似度计算。本文将带你从…

作者头像 李华
网站建设 2026/1/20 2:21:20

Better BibTeX:LaTeX用户的终极文献管理革命

Better BibTeX&#xff1a;LaTeX用户的终极文献管理革命 【免费下载链接】zotero-better-bibtex Make Zotero effective for us LaTeX holdouts 项目地址: https://gitcode.com/gh_mirrors/zo/zotero-better-bibtex 对于长期坚守LaTeX阵地的学者而言&#xff0c;Zotero原…

作者头像 李华
网站建设 2026/1/16 7:24:54

Mac百度网盘SVIP完整解锁终极指南:告别限速烦恼

Mac百度网盘SVIP完整解锁终极指南&#xff1a;告别限速烦恼 【免费下载链接】BaiduNetdiskPlugin-macOS For macOS.百度网盘 破解SVIP、下载速度限制~ 项目地址: https://gitcode.com/gh_mirrors/ba/BaiduNetdiskPlugin-macOS 还在为百度网盘的下载速度而苦恼吗&#xf…

作者头像 李华