hduoj A strange lift---1548

原创 2016年05月30日 19:05:29
//dijkstra算法  最短路径
<pre name="code" class="cpp">#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#define INF 1000000
#define max 205
int n;
int edge[max][max];
int s[max];
int dist[max];
int path[max];
void dijik(int v0)
{
	int i,j,k;
	for(i=1;i<=n;i++)
	{
		dist[i]=edge[v0][i];
		s[i]=0;
		if(i!=v0&&dist[i]<INF) path[i]=v0;
		else path[i]=-1;
	}
	s[v0]=1;
	dist[v0]=0;
	for(i=1;i<n;i++)
	{
		int min=INF,u=v0;
		for(j=1;j<=n;j++)
		{
			if(!s[j]&&dist[j]<min)
			{
				u=j;
				min=dist[j];
			}
		}
		s[u]=1;
		for(k=1;k<=n;k++)
		{
			if(!s[k]&&edge[u][k]<INF&&dist[u]+edge[u][k]<dist[k])
			{
				dist[k]=dist[u]+edge[u][k];
				path[k]=u;
			}
		}
	}
}
int main()
{
	int i,j;
	int b,c,t;
	while(1)
	{
		scanf("%d",&n);
		if(n==0) break;
		else scanf("%d %d",&b,&c); 
		memset(edge,0,sizeof(edge));
		for(i=1;i<=n;i++)
		{
			scanf("%d",&t);
			if(i-t>=1) edge[i][i-t]=1;
			if(i+t<=n) edge[i][i+t]=1;
		}
		for(i=1;i<=n;i++)
		{
			for(j=1;j<=n;j++)
			{
				if(i==j) edge[i][j]=0;
				else if(edge[i][j]==0) edge[i][j]=INF;
			}
		}
		/*for(i=1;i<=n;i++)
		{
			for(j=1;j<=n;j++)
			{
				printf("%d ",edge[i][j]);
			}
			printf("\n");
		}*/
		dijik(b);
		int shortest[max];
		//for(i=1;i<=n;i++)
		//{
			//if(i==b) continue;
			//printf("%d ",dist[i]);
			memset(shortest,0,sizeof(shortest));
			int k=0;
			shortest[k]=c;
			while(path[shortest[k]]!=0)
			{
				k++;
				shortest[k]=path[shortest[k-1]];
			}
			k++;
			shortest[k]=(b);
			//for(j=k;j>0;j--)
			//{
			//	printf("%d->",shortest[j]);
			//}
			if(dist[c]==INF) printf("-1\n");
			else printf("%d\n",dist[c]);
		//}
		
	}
	return 0;
}
/*
5 1 5
3 3 1 2 5
*/



                
版权声明:本文为博主原创文章,未经博主允许不得转载。

A strange lift(简单BFS)

A strange lift Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) ...
  • Enjoying_Science
  • Enjoying_Science
  • 2014年10月04日 18:00
  • 580

HDU1548:A strange lift(Dijkstra && BFS)

Problem Description There is a strange lift.The lift can stop can at every floor as you want, and t...
  • libin56842
  • libin56842
  • 2013年11月25日 19:56
  • 5648

hdu1548 A strange lift(bfs)

A B C D E F G C - A strange lift Crawling in process... Crawling failed Time Limit:100...
  • su20145104009
  • su20145104009
  • 2016年05月30日 17:08
  • 3708

HDU 1548 A strange lift (搜索-深搜、广搜)

There is a strange lift.The lift can stop can at every floor as you want, and there is a number Ki(0...
  • IAccepted
  • IAccepted
  • 2014年04月13日 18:02
  • 2246

HDU 1548 最短路---A strange life

Problem Description There is a strange lift.The lift can stop can at every floor as you want, and t...
  • coco_astrids
  • coco_astrids
  • 2016年11月13日 17:11
  • 89

D - A strange lift

问题描述 There is a strange lift.The lift can stop can at every floor as you want, and there is a num...
  • qq_31237061
  • qq_31237061
  • 2015年12月12日 18:36
  • 190

UVa 712 S-Trees(满二叉树数组保存与编号)

一.满二叉树 我们发现满二叉树的编号具有这样的性质即根节点为n的话,那么其左子树的编号应该是2n,右子树的编号应该是2n+1 ,有了的这样的性质,我们就可以很假单的用线性表来保存满二叉树的节点,注...
  • u013555159
  • u013555159
  • 2016年05月11日 17:19
  • 393

hdu1584 A strange lift (电梯最短路径问题)

A strange lift Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) T...
  • su20145104009
  • su20145104009
  • 2015年07月25日 09:07
  • 1651

hdu 1548 A strange lift Dijkstra+SPFA算法AC

Problem Description There is a strange lift.The lift can stop can at every floor as you want, and th...
  • Lionel_D
  • Lionel_D
  • 2015年03月28日 15:31
  • 653

POJ Balance 1837(01背包)

Balance Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 13585   Accep...
  • ky961221
  • ky961221
  • 2016年08月16日 21:21
  • 99
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:hduoj A strange lift---1548
举报原因:
原因补充:

(最多只允许输入30个字)