acwing搜索与图论(三)prim算法

#include<cstring>
#include<iostream>
#include<algorithm>

using namespace std;

const int N=510,INF=0x3f3f3f3f;

int n,m;
int g[N][N];
int dist[N];
bool st[N];


int prim(){
	memset(dist,0x3f,sizeof dist);
	
	int res=0;
	for(int i=0;i<n;i++){
		
		
		int t=-1;
		for(int j=1;j<=n;j++)
			if(!st[j]&&(t==-1||dist[t]>dist[j]))
				t=j;
			
			if(i&&dist[t]==INF)return INF;
			

			for(int j=1;j<=n;j++)
				{if(t!=j)
				dist[j]=min(dist[j],g[t][j]);}
			
			
			if(i)res+=dist[t];
		
		st[t]=true;
	}
	
	return res;
}


int main(){
	scanf("%d%d",&n,&m);
	memset(g,0x3f,sizeof g);
	
	while(m--){
		int a,b,c;
		scanf("%d%d%d",&a,&b,&c);		
		g[a][b]=g[b][a]=min(g[a][b],c);
		
	}
	
	int t=prim();
	
	if(t==INF){
		puts("imp");
	}
	else 
		printf("%d",t);
	return 0;
	
}

改进了y总的算法,初始算法可能会存在自环,如果自环是负数的那个对于更新dist数组的话,最后的总数会变小,我们需要排除自环,当t==j的时候不更新,这样就可以排除自环。不然需要提前统计res,跟dijksstra思想差不多,不过更新的数据不需要相加,是到集合的最短距离,只需要看看其他点与新入st数组的点的距离有没有更短,有的话就更新,它不只是到起点的距离。

测试数据:

  5 10
  1 2 8
  2 2 7
  2 1 1
  3 4 3
  4 4 -10
  1 3 -9
  5 2 -4
  3 1 0
  1 4 8
  4 4 -7

4 5
1 2 1
1 3 2
1 4 3
2 3 2
3 4 4
相关推荐
Java与Android技术栈7 分钟前
图像编辑器 Monica 之 CV 常见算法的快速调参
算法
别NULL19 分钟前
机试题——最小矩阵宽度
c++·算法·矩阵
珊瑚里的鱼20 分钟前
【单链表算法实战】解锁数据结构核心谜题——环形链表
数据结构·学习·程序人生·算法·leetcode·链表·visual studio
无限码力24 分钟前
[矩阵扩散]
数据结构·算法·华为od·笔试真题·华为od e卷真题
gentle_ice24 分钟前
leetcode——矩阵置零(java)
java·算法·leetcode·矩阵
查理零世26 分钟前
保姆级讲解 python之zip()方法实现矩阵行列转置
python·算法·矩阵
zhbi981 小时前
测量校准原理
算法
时间很奇妙!1 小时前
decison tree 决策树
算法·决策树·机器学习
sysu632 小时前
95.不同的二叉搜索树Ⅱ python
开发语言·数据结构·python·算法·leetcode·面试·深度优先
红鲤鱼遇绿鲤鱼2 小时前
uva 1354 Mobile Computing
算法