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
相关推荐
芒克芒克6 分钟前
LeetCode 面试经典 150 题:删除有序数组中的重复项(双指针思想解法详解)
算法
青 .6 分钟前
数据结构---二叉搜索树的实现
c语言·网络·数据结构·算法·链表
MChine慕青1 小时前
顺序表与单链表:核心原理与实战应用
linux·c语言·开发语言·数据结构·c++·算法·链表
塔中妖1 小时前
【华为OD】查找接口成功率最优时间段
算法·链表·华为od
塔中妖1 小时前
【华为OD】最大子矩阵和
算法·华为od·矩阵
努力学习的小廉2 小时前
深入了解linux系统—— 线程同步
linux·服务器·数据库·算法
数据爬坡ing2 小时前
从挑西瓜到树回归:用生活智慧理解机器学习算法
数据结构·深度学习·算法·决策树·机器学习
luoganttcc2 小时前
小鹏汽车 vla 算法最新进展和模型结构细节
人工智能·算法·汽车
胡耀超3 小时前
3.Python高级数据结构与文本处理
服务器·数据结构·人工智能·windows·python·大模型
云:鸢3 小时前
C语言链表设计及应用
c语言·开发语言·数据结构·链表