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
相关推荐
CoovallyAIHub18 分钟前
避开算力坑!无人机桥梁检测场景下YOLO模型选型指南
深度学习·算法·计算机视觉
YouQian77222 分钟前
问题 C: 字符串匹配
c语言·数据结构·算法
yanxing.D27 分钟前
408——数据结构(第二章 线性表)
数据结构·算法
艾莉丝努力练剑1 小时前
【LeetCode&数据结构】二叉树的应用(二)——二叉树的前序遍历问题、二叉树的中序遍历问题、二叉树的后序遍历问题详解
c语言·开发语言·数据结构·学习·算法·leetcode·链表
YuTaoShao1 小时前
【LeetCode 热题 100】51. N 皇后——回溯
java·算法·leetcode·职场和发展
1 小时前
3D碰撞检测系统 基于SAT算法+Burst优化(Unity)
算法·3d·unity·c#·游戏引擎·sat
Tony沈哲1 小时前
OpenCV 图像调色优化实录:基于图像金字塔的 RAW / HEIC 文件加载与调色实践
opencv·算法
我就是全世界2 小时前
Faiss中L2欧式距离与余弦相似度:究竟该如何选择?
算法·faiss
boyedu2 小时前
比特币运行机制全解析:区块链、共识算法与数字黄金的未来挑战
算法·区块链·共识算法·数字货币·加密货币
waveee1232 小时前
学习嵌入式的第三十三天-数据结构-(2025.7.25)服务器/多客户端模型
服务器·数据结构·学习