最近在做一些题目,发现好多东西我都不会,顺便就把去年学的数据结构复习一点。
Dijsktra这个算法我感觉是比较符合人类的思维方式的,从一个顶点到其他顶点的最短路径,稍微动一下脑筋就会知道,寻找最近的路径就是在经过所有可以到达目的地的最短。AB<ACB就是这样的。因此并不防设为ABCDEF要求从A点到达其他各点的最短路径。首先设置一个数组装从A直接到达的路径长度。
void Dijkstra(int n,int v,int dist[],int prev[],int c[][NUM])
{
int i,j;
int s[NUM];
0 | 1 | 1 | 1 | 1 |
//初始化数组
for(i=1;i<=n;i++)
{
dist[i]=c[v][i];//数组保存各个顶点到原点的直接距离
s[i]=0;//s[i]=1表示到达原点的最短路径
if(dist[i]>maxint)
prev[i]=0;
else prev[i]=v;
}
//初始化源节点
dist[v]=0;
s[v]=1;
for(i=1;i<n;i++)
{
int tmp=maxint;
int u=v;
for(j=1;j<=n;j++)
if(!s[j]&&dist[j]<tmp)
{
u=j;
tmp=dist[j];
}
s[u]=1;//节点U加入S中
for(j=1;j<=n;j++)
if(!(s[i])&&c[u][j]<maxint)
{
int newdist=dist[u]+c[u][j];
if(newdist<dist[j])
{
dist=newdist;
prev[j]=u;
}
}
}
}