pat1003 迪杰斯特拉法和dfs求最短路

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了pat1003 迪杰斯特拉法和dfs求最短路相关的知识,希望对你有一定的参考价值。

本题的背景是求定点和定点之间的最短路问题,方法手段来自数据结构课程中的迪杰斯特拉算法和dfs(深度优先遍历)。

分别用两种方法编程如下代码

  • dfs
#include <iostream>
#include <cstring>
#include <cstdio>
using namespace std;
#define maxv 510
bool visit[maxv];

int arc[maxv][maxv];//邻接矩阵

int M,N,C1,C2;      //M总顶点数,N总边数,C1起点,C2终点

int vex[maxv];	    //记录每个顶点的救援人数

int mind=0xfffffff,maxr=0,cnt;//mind最短路径,maxr最大救援人数,cnt最短路径条数

void  dfs(int st,int end,int curPath,int curRes){
	if (st==end){
		if (curPath<mind){
			cnt=1;
			mind=curPath;
			maxr=curRes;
		}else if(curPath==mind){
			cnt++;
			if (curRes>maxr)
				maxr=curRes;
		}
		return;
	}
	else{
		for (int k=0;k<M;k++){
			if (arc[st][k]!=0&&!visit[k]){
				visit[k]=1;
				dfs(k,end,curPath+arc[st][k],curRes+vex[k]);
				visit[k]=0;
			}
	    }
		return ;
	}
}
int main(){
	while(scanf("%d%d%d%d",&M,&N,&C1,&C2)!=EOF){
		memset(arc,0,sizeof(arc));
		for(int i=0;i<M;i++)
			scanf("%d",&vex[i]);
        int i,j,d;
		for(int k=0;k<N;k++){
			scanf("%d%d%d",&i,&j,&d);
			arc[j][i]=arc[i][j]=d;
		}
		memset(visit,0,sizeof(visit));
		visit[C1]=1;
		dfs(C1,C2,0,vex[C1]);
		printf("%d %d",cnt,maxr);
	}
	return 0;
}
  1. 容易放的错误是mind,maxr忘记赋初始值    
  2. 矩阵scanf输入的时候&arg[i][j]  不会报错  但会导致输入异常   这个问题我也很奇怪  先在这里记录说明了

 

  •   迪杰斯特拉算法

以上是关于pat1003 迪杰斯特拉法和dfs求最短路的主要内容,如果未能解决你的问题,请参考以下文章

编写的迪杰斯特拉算法求最短路径,运行不正确?

迪杰斯特拉算法——PAT 1003

最短路径(迪杰斯特拉算法)

1003 Emergency(考察迪杰斯特拉算法+第二标尺)

1111 Online Map(迪杰斯特拉+DFS)

迪杰斯克拉算法是怎样的?