最小生成树详解

注:本文算法使用链式前向星数据结构实现。学习链接:链式前向星-学习笔记

一、Prim算法

普通prim算法模板:

//用前向星录数据的时候记得把head初始化为-1 
fill(dist,dist+LEN,MAX);
memset(vis,0,sizeof vis);
int ans=0;
dist[1]=0;        //如果题目要求输出最小生成树,就把题目要求的源点s的dist设为0 
while(1){        //如果题目要求判断最小生成树是否能覆盖所有边,这个循环条件应该是i=n;while(n--)循环n次。 int u=-1,d=MAX;for(i=1;i<=N;i++){if(!vis[i] && dist[i]<d){u=i;d=dist[i];}}if(u<0) break;    //如果题目要求判断最小生成树是否能覆盖所有边,出现这样的情况说明不能覆盖所有边。 vis[u]=1;ans+=dist[u];for(i=head[u];~i;i=mp[i].next){    //用前向星遍历u点所有的后继。i是各个后继点在mp的下标,mp[to]是u的各个后继点 int to=mp[i].to;if(!vis[to] && mp[i].w<dist[to]){//如果这个点没有被访问过、并且u->v的路径比点集S到v的路径要短,则更新。 dist[to]=mp[i].w;}}
}
O("%d\n",ans);

堆优化的prim算法:

堆结构:

struct cmp{bool operator () (int a,int b){return dist[a]>dist[b];}
}; 
priority_queue<int,vector<int>,cmp> pq;

算法代码:

int ans=0;
dist[1]=0;
pq.push(1);
while(!pq.empty()){int u=pq.top();pq.pop();if(vis[u]) continue;vis[u]=1;ans+=dist[u];for(i=head[u];~i;i=mp[i].next){int to=mp[i].to;if(!vis[to] && mp[i].w<dist[to]){dist[to]=mp[i].w;pq.push(to);}}
}
O("%d\n",ans);

 

二、Kruskal算法

1.建立边表数据结构

typedef struct edge{int u,v,w;edge(int u=0,int v=0,int w=0):u(u),v(v),w(w){}bool operator < (const edge& obj) const{return w<obj.w;}
}edge;
edge mp[LEN*LEN];

2.编写并查集模板(以下代码没有写合并的Union操作。这个操作在主代码执行的时候已经实现)

int fa[LEN];
int init(){int i;FF(i,LEN) fa[i]=i;
}
int findFa(int x){if(x==fa[x]) return x;int r=x;while(r!=fa[r]){r=fa[r];}int t=x;while(x!=fa[x]){t=fa[x];fa[x]=r;x=t;}return r;
}

3.编写主代码

sort(mp,mp+cnt);
FF(i,cnt){int fa_u=findFa(mp[i].u);int fa_v=findFa(mp[i].v);if(fa_u!=fa_v){ans+=mp[i].w;fa[fa_u]=fa_v;edge_cnt++;if(edge_cnt>=N-1) break;}
}
O("%d\n",ans);

注意:

①边表的范围要开大,因为边的数目可能是顶点数目的平方(准确说,有向图边树E=N*(N-1) )

②Prim算法在录边的数据的时候,因为是无向图,一条边要录成两条。Kruskal就没有这种必要了。

③各种初始化代码(比如并查集的init() )要注意加上。

 

打个OJ测试一下吧!

OJ链接:还是畅通工程

AC代码:

#include <stdio.h>
#include <memory.h>
#include <math.h>
#include <string>
#include <vector>
#include <set>
#include <stack>
#include <queue>
#include <algorithm>
#include <map>#define I scanf
#define OL puts
#define O printf
#define F(a,b,c) for(a=b;a<c;a++)
#define FF(a,b) for(a=0;a<b;a++)
#define FG(a,b) for(a=b-1;a>=0;a--)
#define LEN 1010
#define MAX (1<<30)-1
#define V vector<int>using namespace std;int N;
int fa[LEN];
int init(){int i;FF(i,LEN) fa[i]=i;
}
int findFa(int x){if(x==fa[x]) return x;int r=x;while(r!=fa[r]){r=fa[r];}int t=x;while(x!=fa[x]){t=fa[x];fa[x]=r;x=t;}return r;
}typedef struct edge{int u,v,w;edge(int u=0,int v=0,int w=0):u(u),v(v),w(w){}bool operator < (const edge& obj) const{return w<obj.w;}
}edge;
edge mp[LEN*LEN];
int cnt=0;int main(){
//    freopen("还是畅通工程.txt","r",stdin);int i,j,u,v,w;while(scanf("%d",&N),N){init();cnt=0;int ans=0;int edge_cnt=0;i=(N*(N-1))/2;while(i--){I("%d%d%d",&u,&v,&w);mp[cnt++]=edge(u,v,w);
//            mp[cnt++]=edge(v,u,w);
        }sort(mp,mp+cnt);FF(i,cnt){int fa_u=findFa(mp[i].u);int fa_v=findFa(mp[i].v);if(fa_u!=fa_v){ans+=mp[i].w;fa[fa_u]=fa_v;edge_cnt++;if(edge_cnt>=N-1) break;}}O("%d\n",ans);}return 0;
}
View Code

 

转载于:https://www.cnblogs.com/TQCAI/p/8549353.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/281008.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

dropbox文件_Dropbox即将发布的扩展程序更新将添加更多文件编辑支持,包括Pixlr照片...

dropbox文件Dropbox is perhaps the best-known cloud storage platform for consumers, but it’s hoping to become something more. With an upcoming overhaul to its user tools, Dropbox will add more complex editing tools, in addition to what it already provides …

黑客窃取思科、IBM与甲骨文认证管理系统内的敏感数据

目前一套被思科、F5、IBM以及甲骨文等企业所广泛使用的认证管理系统(即Credential Manager System)正面临着数据泄露风险&#xff0c;其中的敏感数据也许已经被黑客们所获取。 根据Pearson VUE(主营计算机测试方案开发与交付)发布的一项公告&#xff0c;某恶意软件已经藏身于该…

Spring下载地址

下载地址&#xff1a;https://repo.spring.io/libs-release-local/org/springframework/spring/ 进入后可选择下载版本&#xff0c;选择版本后&#xff0c;进入目录结构。其中dist是最终发布版本&#xff0c;包含开发所需lib和源码。docs是开发文档。schema是一些约束文件。 Do…

.NET7发布,一大批优秀.NET6项目没人看了吗...(都是好项目)

恍惚间都已经.NET7.0了&#xff0c;不能再呆在旧版本了&#xff01;这里分享一套Vue3 Axios TS Vite Element Plus .NET 6 WebAPI JWT SqlSugar的通用管理后台&#xff0c;各种最新框架组件&#xff0c;学习必备&#xff01;这里把源码、脚本以及专门录制的视频教程都打…

Python的日志记录-logging模块的使用

一、日志 1.1什么是日志 日志是跟踪软件运行时所发生的事件的一种方法&#xff0c;软件开发者在代码中调用日志函数&#xff0c;表明发生了特定的事件&#xff0c;事件由描述性消息描述&#xff0c;同时还包含事件的重要性&#xff0c;重要性也称为级别或严重性。 1.2何时使用日…

询问HTG:白噪声屏幕保护程序,有效的文件命名以及从密码泄露中恢复

Once a week we share three of the questions we’ve answered from the Ask HTG inbox with the greater readership; this week we’re looking at white noise screen savers, efficient file naming systems, and recovering from a password compromise. 每周一次&#…

专家预测第二波WannaCry勒索病毒攻击即将到来!

WannaCry的传播脚步今晨戛然而止 今天一大早&#xff0c;全网的WannaCry蠕虫病毒攻击突然减弱消退了!所有这一切功劳来自于英国研究人员malwaretech&#xff0c;他通过逆向发现WannaCry代码中有一个特殊域名地址&#xff1a; www.iuqerfsodp9ifjaposdfjhgosurijfaewrwergwea.co…

01.HTML基础命令笔记

目录 HTML结构 body内常用标签 常用 div与span img a标签 超链接标签 其他格式标签 列表 表格 表单 select标签 label标签 textarea多行文本 HTML结构 <!DOCTYPE html> <html lang"zh-CN"> <head><meta charset"UTF-8"&…

ios numlock_从“提示”框:默认情况下启用NumLock,无广告的iOS应用和立体声供电的派对灯...

ios numlockOnce a week we round up some of the great tips readers have sent into the tip box. This week we’re looking at how to enable the NumLock by default, stripping ads from iOS apps, and turning Christmas lights into audio-responsive party lights. 每…

Windows 7 自动更新失败导致无法进系统解决方案

故障现象&#xff1a;自动更新后&#xff0c;重启电脑&#xff0c;提示&#xff1a;&#xff08;配置Windows update 失败 还原更改 请勿关闭计算机&#xff09;&#xff0c; 而计算机一直停留该界面&#xff0c;如果半个小时以上都无反应。此时&#xff0c;就不要再继续等待了…

PaperWeekly 第28期 | 图像语义分割之特征整合和结构预测

“ 余昌黔 华中科技大学硕士 研究方向为图像语义分割 知乎专栏 https://zhuanlan.zhihu.com/semantic-segmentation 前言 近来阅读了 PASCAL VOC 2012 排行榜上前几的文章&#xff0c;包括 PSPNet 和林国省老师的几篇论文&#xff0c;觉得现在在 semantic segmentation 领域对于…

02.CSS基础笔记及导入

CSS是什么 CSS&#xff08;Cascading Style Sheet&#xff0c;层叠样式表)定义如何显示HTML元素。 当浏览器读到一个样式表&#xff0c;它就会按照这个样式表来对文档进行格式化&#xff08;渲染&#xff09;。 CSS样式 CSS引入HTML 内部样式与外部样式 <!DOCTYPE> …

如何还原桌面图标_如何为Windows 10桌面图标还原或更改文本的默认外观?

如何还原桌面图标For whatever reason, sooner or later we all have someone or something mess around with our keyboards and create ‘interesting’ results. With that in mind, today’s SuperUser Q&A post has a simple and elegant way to help a frustrated re…

「前端早读君007」css进阶之彻底理解视觉格式化模型

今日励志 不论你在什么时候开始&#xff0c;重要的是开始之后不要停止。 前言 对于部分前端工程师来讲&#xff0c;有时候CSS令他们很头疼&#xff0c;明明设置了某个样式&#xff0c;但是布局就是不起作用。 如果你也有这种问题&#xff0c;那么是时候学习下什么是css视觉格式…

.NET周报【11月第3期 2022-11-22】

国内文章.NET Conf China 2022 第一批讲师阵容大揭秘&#xff01;整个期待了&#xff01;https://mp.weixin.qq.com/s/4p89hhBPw6qv-0OB_T_TOg目光看过来 2022 年 12 月 3-4 日&#xff0c;一场社区性质的国内规模最大的 线上线下.NET Conf 2022 技术大会 即将盛大开幕。目前大…

解读Facebook CAN:如何给人工智能赋予艺术创作的力量

雷锋网 AI 科技评论按&#xff1a;能够迭代进化、模仿指定数据特征的GAN&#xff08;生成式对抗性网络&#xff09;已经是公认的处理图像生成问题的好方法&#xff0c;自从提出以来相关的研究成果不少&#xff0c;在图像增强、超分辨率、风格转换任务中的效果可谓是惊人的。 &a…

全向轮底盘磁导轨寻迹

全向轮底盘上安装两条磁传感器带用于磁导轨寻迹 如简图所示&#xff0c;两条与Y直线相交的黑色线条我们认为是两条磁检测传感器带 矢量方法修正车体位置 定义轨道左为负向&#xff0c;轨道右为正向。传感器左检测为负&#xff0c;右检测为正&#xff1b; 定义底盘坐标系为αβ&…

02-1.CSS边框,边界,布局相关笔记

目录 CSS盒子模型 padding内填充 边框 边框属性 border-radius margin外边距 CSS盒子模型 Content(内容): 盒子的内容&#xff0c;显示文本和图像 >>>>类似word 文字A&#xff0c;改变字体与大小padding: 用于控制内容与边框之间的距离 …

android仿ios弹框_在“提示”框中:iOS外观(在Android上运行),Google Maps作为Time Machine,下载Wii游戏保存...

android仿ios弹框Once a week we round up some great reader tips and share them with everyone. Read on to see how to make your Android phone look like iOS, use a Google Maps mashup like a time machine, and download Wii game saves. 每周一次&#xff0c;我们收集…

使用 C# 开发的摸鱼背单词软件 ToastFish

你好&#xff0c;这里是 Dotnet 工具箱&#xff0c;定期分享 Dotnet 有趣&#xff0c;实用的工具和组件&#xff0c;希望对您有用&#xff01;摸鱼神器ToastFish 是一个使用 C# 开发的桌面软件&#xff0c;由 Uahh 开发&#xff0c; 这是一个利用Windows通知栏背单词的软件&…