用C++求dijkstra算法求最短路径

问题描述:从键盘上输入一个图的基本信息(图用邻矩阵表示)1)首先输入图的结点数->num2)依次输入图的各条边3)程序所能达到的功能:输出用dijkstra算法求出的一条... 问题描述:从键盘上输入一个图的基本信息(图用邻矩阵表示)
1)首先输入图的结点数->num
2)依次输入图的各条边
3)程序所能达到的功能:输出用dijkstra算法求出的一条最短路径。
展开
 我来答
qilihechuncai
2008-12-21
知道答主
回答量:1
采纳率:0%
帮助的人:0
展开全部
/**************************************************************
* 给定一个带权有向图G = (V,E),其中每条边的权是一个非负整数。*
* 另外还给定V中的一个顶点,称为源。现在我们要计算从源到所有其 *
* 他各顶点的最短路长度。这里路径长度是路上各边权之和。这个问 *
* 题通常称为单源最短路径问题。 *
***************************************************************/
#include<iostream.h>

#define INFINITE 100

void main()
{
int j,i,n,k,t,**w,*s,*p,*d;

cout<<"input the value of n:";
cin>>n;
cout<<endl;

d = new int[n];
s = new int[n];
p = new int[n];
w = new int*[n];

for(i = 0; i < n; i++)
{
w[i] = new int[n];
}

for(i = 0; i < n; i++)
for(j = 0; j < n; j++)
cin>>w[i][j];

for(s[0] = 1,i = 1; i < n; i++)
{
s[i] = 0;
d[i] = w[0][i];
if(d[i] < INFINITE)
p[i]=0;
else
p[i]=-1;
}

for(i = 1; i < n; i++)
{
t = INFINITE;
k = 1;
for(j = 1; j < n; j++)
if((!s[j]) && (d[j] < t))
{
t = d[j];
k = j;
}
s[k]=1;//point k join the S
for (j = 1; j < n; j++)
if((!s[j]) && (d[j] > d[k] + w[k][j]))
{
d[j] = d[k] + w[k][j];
p[j] = k;
}

}
cout<<"从源点到其它顶点的最短距离依次如下:";
for(i=1;i<n;i++) cout<<d[i]<<" ";
cout<<endl;

}
/*********
顶点个数用n表示,这里给出的例子n=6
100 1 12 100 100 100
100 100 9 3 100 100
100 100 100 100 5 100
100 100 4 100 13 15
100 100 100 100 100 4
100 100 100 100 100 100
具体例子见 电子工业出版社 《算法设计技巧与分析》148页
************/
宾雪路天蓝
2019-03-16 · TA获得超过4089个赞
知道大有可为答主
回答量:3063
采纳率:29%
帮助的人:193万
展开全部
/**************************************************************
*
给定一个带权有向图G
=
(V,E),其中每条边的权是一个非负整数。*
*
另外还给定V中的一个顶点,称为源。现在我们要计算从源到所有其
*
*
他各顶点的最短路长度。这里路径长度是路上各边权之和。这个问
*
*
题通常称为单源最短路径问题。
*
***************************************************************/
#include<iostream.h>
#define
INFINITE
100
void
main()
{
int
j,i,n,k,t,**w,*s,*p,*d;
cout<<"input
the
value
of
n:";
cin>>n;
cout<<endl;
d
=
new
int[n];
s
=
new
int[n];
p
=
new
int[n];
w
=
new
int*[n];
for(i
=
0;
i
<
n;
i++)
{
w[i]
=
new
int[n];
}
for(i
=
0;
i
<
n;
i++)
for(j
=
0;
j
<
n;
j++)
cin>>w[i][j];
for(s[0]
=
1,i
=
1;
i
<
n;
i++)
{
s[i]
=
0;
d[i]
=
w[0][i];
if(d[i]
<
INFINITE)
p[i]=0;
else
p[i]=-1;
}
for(i
=
1;
i
<
n;
i++)
{
t
=
INFINITE;
k
=
1;
for(j
=
1;
j
<
n;
j++)
if((!s[j])
&&
(d[j]
<
t))
{
t
=
d[j];
k
=
j;
}
s[k]=1;//point
k
join
the
S
for
(j
=
1;
j
<
n;
j++)
if((!s[j])
&&
(d[j]
>
d[k]
+
w[k][j]))
{
d[j]
=
d[k]
+
w[k][j];
p[j]
=
k;
}
}
cout<<"从源点到其它顶点的最短距离依次如下:";
for(i=1;i<n;i++)
cout<<d[i]<<"
";
cout<<endl;
}
/*********
顶点个数用n表示,这里给出的例子n=6
100
1
12
100
100
100
100
100
9
3
100
100
100
100
100
100
5
100
100
100
4
100
13
15
100
100
100
100
100
4
100
100
100
100
100
100
具体例子见
电子工业出版社
《算法设计技巧与分析》148页
************/
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式