NOJ_1049 飞机最少换乘次数

飞机最少换乘次数问题

时间限制(普通/Java): 1000MS/3000MS 运行内存限制:65536KByte
总提交:467 测试通过:205

比赛描述

设有n个城市,编号为0n-1m条单向航线的起点和终点由输入提供,寻找一条换乘次数最少的线路方案。<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />



输入

第一行为三个整数nmv,表示城市数、单向航线数和起点城市。以下m行每行两个整数,表示一条边的起点、终点,保证不重复、不失败。2n201m190

输出

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;
}




你可能感兴趣的:(ACM)