最短路C++ 蓝桥杯

题目描述
本题为填空题,只需要算出结果后,在代码中使用输出语句将所填结果输出即可。
如下图所示,G 是一个无向图,其中蓝色边的长度是 1、橘色边的长度是 2、绿色边的长度是 3。在这里插入图片描述则从 AA 到 SS 的最短距离是多少?

运行限制
最大运行时间:1s
最大运行内存: 128M

最短路径模板题,初始化比较麻烦,一共36条路径。
我初始化的时候A-S分别用1-19代替。初始化的时候保证从一个小的数字出发到一个大一点的数字。这样就不会重复了。
#include<bits/stdc++.h>
using namespace std;
#define lnf 0x7FFFFFFF
int dis[25],vis[25];
int imap[25][25];
void iset(int x,int y,int num){
	imap[x][y]=imap[y][x]=num;
	cout<<imap[x][y]<<endl;
}
void intial(){
	iset(1,5,1);iset(1,4,1);iset(1,3,1);iset(1,2,2);
	iset(2,7,1);iset(2,10,2);
	iset(3,4,3);iset(3,7,3);iset(3,6,3);
	iset(4,5,1);iset(4,9,2);iset(4,8,1);iset(4,7,2);
	iset(5,9,3);iset(5,8,1);
	iset(6,7,1);iset(6,10,1);
	iset(7,9,3);iset(7,11,2);
	iset(8,9,1);iset(8,12,2);
	iset(9,13,3);
	iset(10,19,2);
	iset(11,12,3);iset(11,16,2);iset(11,14,1);
	iset(12,13,1);iset(12,18,1);
	iset(13,19,1);iset(13,17,1);iset(13,14,2);
	iset(14,16,1);
	iset(15,17,1);iset(15,18,3);iset(15,16,1);
	iset(18,19,1);
}
int main()
{
	for(int i=1;i<=25;i++){
		vis[i]=1;
		dis[i]=lnf;
		for(int j=1;j<=25;j++)
		imap[i][j]=lnf;
	}
	intial();
	int s=1;
	int t=19;
	dis[s]=0;
	vis[s]=0;
	int imin;
	int inext;
	for(int i=1;i<=19;i++){
		for(int j=1;j<=18;j++){
			cout<<imap[i][j]<<" ";
		}
		cout<<endl;
	}
	while(s!=t){
		imin=lnf;
		for(int i=1;i<=19;i++){
			if(imap[s][i]!=lnf)
			dis[i]=min(dis[i],dis[s]+imap[s][i]);
			
			if(vis[i]&&dis[i]<imin){
				imin=dis[i];
				inext=i;
			}
		}
		if(imin==lnf)
		break;
		s=inext;
		vis[s]=0;
	}
	cout<<endl;
	for(int i=1;i<=19;i++)
	cout<<dis[i]<<" ";
	cout<<endl;
	cout<<dis[t]<<endl;
    return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值