飞机最少换乘次数问题
时间限制(普通/Java):
1000MS/3000MS 运行内存限制:65536KByte
总提交:467 测试通过:205
总提交:467 测试通过:205
比赛描述
设有n个城市,编号为0~n-1,m条单向航线的起点和终点由输入提供,寻找一条换乘次数最少的线路方案。<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />
输入
第一行为三个整数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
算是第一次做图相关的题目,自己乱写了一个方法,发现别人都是0MS,我是5MS,然后再翻开许久没翻过的《数据结构》,发现,我这个方法还真是独树一帜。。慢慢学习图的知识,用图的方法去完善这个程序,慢慢补充这篇blog。
#include<stdio.h>
int V[20];
int E[190][2];
int E_num;
huanchengcishu(int start,int cishu)
{
int i;
for(i=0;i<E_num;i++)
if(E[i][0]==start && V[E[i][1]]==-1)
{
V[E[i][1]]=cishu;
huanchengcishu(E[i][1],cishu+1);
}
}
int main()
{
int i,V_num,start;
scanf("%d %d %d",&V_num,&E_num,&start);
for(i=0;i<E_num;i++)
{
scanf("%d %d",&E[i][0],&E[i][1]);
}
for(i=0;i<V_num;i++)
V[i]=-1;
// V[start]=0;
huanchengcishu(start,1);
for(i=0;i<V_num;i++)
if(i!=start)
printf("%d\n",V[i]);
return 0;
}