本文来讲解一下用c++来设计一个关于最短路径的程序。
1.首先把图片中的各个景点(地方)绘制成一个无向带权图。
2.将图中的景点绘制成无向带权图为:Q——R = 7(补充)
以上用A,B,C,D…来代替以上20个地方。
3.用弗洛伊德拉算法来实现两点间最短路径查找:
(1).先把数据按 顶点 顶点 权值 (A B 8 表示A和B之间的路径大小为8)储存在一个名为"data.txt"文档中方便读取。(若不直接相连则权值为99,意为无穷大)
(2).然后按格式读取文件数据内容,构建一个邻接带权矩阵
//找出顶点对应的下标
int find_position(char arg)
{
for(int K=0;K<vertexNum;K++)
{
if(vertex[K] == arg)
return K;
}
};
void read_data()
{
char first,last;
int firstNumber,lastNumber,weight;
string line;
ifstream file("data.txt");//打开文件
while(!file.eof())
{
getline(file,line);
if(line.size()==5)//5代表权值是小于10
{
first = line[0];
last = line[2];
weight = line[4]-48;//用ASCII码值来转换
}
else
{
first = line[0];
last = line[2];
weight = (line[4]-48)*10+(line[5]-48);//用ASCII码值来转换
}
firstNumber = find_position(first);
lastNumber = find_position(last);
edge[firstNumber][lastNumber] = weight;//更新权值
}
}
(3).构建完邻接矩阵之后,用弗洛伊德算法把算出一个最后路径权值矩阵 和 路径矩阵
void Floyd()
{
int i,j,k,dist[20][20];
string path[20][20];
for(i=0;i<20;i++)
for(j=0;j<20;j++)
{
dist[i][j]=edge[i][j];
if(dist[i][j]!=99 && dist[i][j]!=0)
{
//不能直接相加,字符直接相加会转换为ASCII码相加后得到另一个字符
//path[i][j] = vertex[i]+vertex[j];
path[i][j] = vertex[i];
path[i][j] = path[i][j]+vertex[j];
}
//若为99或0则为空
else
path[i][j]="";
}
for(k=0;k<20;k++)
for(i=0;i<20;i++)
for(j=0;j<20;j++)
{
if(dist[i][k] + dist[k][j] < dist[i][j])
{
dist[i][j]=dist[i][k] + dist[k