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
相关推荐
电鱼智能的电小鱼44 分钟前
基于电鱼 AI 工控机的智慧工地视频智能分析方案——边缘端AI检测,实现无人值守下的实时安全预警
网络·人工智能·嵌入式硬件·算法·安全·音视频
孫治AllenSun1 小时前
【算法】图相关算法和递归
windows·python·算法
格图素书2 小时前
数学建模算法案例精讲500篇-【数学建模】DBSCAN聚类算法
算法·数据挖掘·聚类
yuuki2332333 小时前
【数据结构】用顺序表实现通讯录
c语言·数据结构·后端
DashVector3 小时前
向量检索服务 DashVector产品计费
数据库·数据仓库·人工智能·算法·向量检索
AI纪元故事会3 小时前
【计算机视觉目标检测算法对比:R-CNN、YOLO与SSD全面解析】
人工智能·算法·目标检测·计算机视觉
夏鹏今天学习了吗3 小时前
【LeetCode热题100(59/100)】分割回文串
算法·leetcode·深度优先
卡提西亚3 小时前
C++笔记-10-循环语句
c++·笔记·算法
还是码字踏实3 小时前
基础数据结构之数组的双指针技巧之对撞指针(两端向中间):三数之和(LeetCode 15 中等题)
数据结构·算法·leetcode·双指针·对撞指针
Coovally AI模型快速验证6 小时前
当视觉语言模型接收到相互矛盾的信息时,它会相信哪个信号?
人工智能·深度学习·算法·机器学习·目标跟踪·语言模型