c++来写一个求最短路径算法的程序

本文介绍了如何用C++编写一个求最短路径的程序,通过绘制无向带权图,利用弗洛伊德算法计算两点间的最短路径。程序从"data.txt"文件读取图数据,构建邻接矩阵,最终输出最短路径及权值。虽然是作者初次尝试,可能存在小错误,但能完成基本功能。
摘要由CSDN通过智能技术生成

本文来讲解一下用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
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值