(迪杰斯特拉)Dijkstra算法 与 普里姆算法(Prim算法)

怎么硕呢

这俩肯定是一个人抄了另一个人的代码。就在花费那一部分  一个是d[u] = mp[u][v]+d[v] (迪杰斯特拉)  另一个是d[u] = mp[u][v]

大体思路就是一直找和以之节点相通的节点之间最省钱的路径就完了。

相比较克鲁斯卡尔来说,一个是以点展开验证边。而克鲁斯卡尔是以边为展开看连接点点是否属于都一个跟(并查集)

迪杰斯特拉:

#include
#include
#define INF 0x3f3f3f3f
//测试样例
//4 6
//1 2 1 
//1 3 4 
//1 4 1 
//2 3 3 
//2 4 2 
//3 4 5 
int vis[100];
int money[100][100];
int n;
void Dijkstra(int x)
{
	int v,u;
	int d[100];
	int p[100];
	memset(d,INF,sizeof(d));
	memset(vis,0,sizeof(vis));
	memset(p,-1,sizeof(p));
	d[x]=0;
	
	while(1){
		u=-1;
		int minv=INF;
		for(int i=0;imoney[u][v]+d[u])
				{
					d[v]=money[u][v]+d[u];
					p[v]=u;
				}
			}
		}
	}
	
	int sum=0;
	for(int i=0;i

 

普利姆:

#include
#include
#define INF 0x3f3f3f3f
//测试样例
//4 6
//1 2 1 1
//1 3 4 0
//1 4 1 1
//2 3 3 0
//2 4 2 1
//3 4 5 0 
int vis[100];
int money[100][100];
int n;
void prim()
{
	int v,u;
	int d[100];
	int p[100];
	memset(d,INF,sizeof(d));
	memset(vis,0,sizeof(vis));
	memset(p,-1,sizeof(p));
	d[0]=0;
	
	while(1)
	{
		u=-1;
		int minv=INF;
		for(int i=0;imoney[u][v])
				{
					d[v]=money[u][v];
					p[v]=u;
				}
			}
		}
	}
	
	int sum=0;
	for(int i=0;i

 

你可能感兴趣的:(考研,图)