南邮 OJ 1049 飞机最少换乘次数问题
来源:互联网 发布:mac怎么看系统版本号 编辑:程序博客网 时间:2024/04/29 03:19
飞机最少换乘次数问题
时间限制(普通/Java) : 1000 MS/ 3000 MS 运行内存限制 : 65536 KByte
总提交 : 467 测试通过 : 205
总提交 : 467 测试通过 : 205
比赛描述
设有n个城市,编号为0~n-1,m条单向航线的起点和终点由输入提供,寻找一条换乘次数最少的线路方案。
输入
第一行为三个整数n、m、v,表示城市数、单向航线数和起点城市。以下m行每行两个整数,表示一条边的起点、终点,保证不重复、不失败。2≤n≤20,1≤m≤190
输出
共n-1行,分别是从起点城市v到其他n-1个城市最少换乘次数,按照终点城市序号从小到大顺序输出,不能抵达时输出-1。
样例输入
3 2 0
0 1
1 2
样例输出
1
2
题目来源
CHENZ
#include<iostream>#define MAX_N 20bool map[MAX_N][MAX_N];bool visited[MAX_N];int dis[MAX_N];int main(){int n,m,v,b,e,i,currentNode,currentDis;scanf("%d%d%d",&n,&m,&v);for(i=0;i<m;i++){scanf("%d%d",&b,&e);map[b][e] = 1;}for(i=0;i<n;i++){dis[i]= INT_MAX;}dis[v] = 0;currentNode = v;while(currentNode != -1){visited[currentNode] = 1;currentDis = dis[currentNode];for(i=0;i<n;i++){//currentDis加入之后,更新所有的距离信息if(!visited[i] && map[currentNode][i] && dis[i]>currentDis+1){dis[i] = currentDis +1;}}currentNode = -1;currentDis = INT_MAX;for(i=0;i<n;i++){//找到下一个最近的点if(!visited[i] && currentDis>dis[i]){currentNode = i;currentDis = dis[i];}}}for(i=0;i<n;i++){if(i==v){continue;}if(dis[i]!=INT_MAX){printf("%d\n",dis[i]);}else{printf("-1\n");}}}
0 0
- 南邮 OJ 1049 飞机最少换乘次数问题
- 【NOJ】1049 飞机最少换乘次数问题
- 飞机最少换乘次数问题
- 飞机最少换乘次数问题
- NOJ_1049 飞机最少换乘次数
- NOJ1049飞机最少换乘次数问题——BFS
- 飞机换乘次数最少问题的两种解决方案
- 南邮数据结构实验三---图的基本运算及飞机换乘次数最少问题
- 飞机最少换乘(迪杰斯特拉实验)
- 数据结构实验3(飞机最少环城次数问题)
- 南邮数据结构实验三——飞机换乘最小次数问题
- 南邮数据结构实验3 (2)飞机最少换乘
- 最少换乘
- 最少换乘
- 飞机最小换乘次数&宽度优先遍历(bfs)
- 南邮 OJ 1221 最少硬币问题
- 最少换乘 第八届
- NYOJ 1238 最少换乘
- 音乐治疗处方
- 分享下我成为大讲台自适应学习系统内测员的经验
- typedef常见用法
- cuda
- iOS学习笔记5-MPMoviePlayerController详解
- 南邮 OJ 1049 飞机最少换乘次数问题
- 『Spring.NET+NHibernate+泛型』框架搭建之WebUI(五)★
- iOS 9之Safari广告拦截器(Content Blocker)
- 如果让我重新设计一款Android App
- IM系统架构设计之浅见
- 天声人語 20150804
- JDBC及eclipse连接数据库
- hdu 1671 phone list(字典树)
- python3入门之几个函数变化