当前位置: 首页 > news >正文

广州网站建设总结建设网站的步骤

广州网站建设总结,建设网站的步骤,软件开发文档编写,wordpress主题在哪里一.介绍 Kruskal(克鲁斯卡尔)算法是一种用于解决最小生成树问题的贪心算法。最小生成树是指在一个连通无向图中,选择一棵包含所有顶点且边权重之和最小的树。 下面是Kruskal算法的基本步骤: 将图中的所有边按照权重从小到大进行…

一.介绍

 Kruskal(克鲁斯卡尔)算法是一种用于解决最小生成树问题的贪心算法。最小生成树是指在一个连通无向图中,选择一棵包含所有顶点且边权重之和最小的树。

下面是Kruskal算法的基本步骤:

  1. 将图中的所有边按照权重从小到大进行排序
  2. 创建一个空的最小生成树集合(并查集实现)
  3. 遍历排序后的边,依次将边加入最小生成树集合中,但要确保加入的边不会形成环路。
    • 如果加入边后不会形成环路,则将该边加入最小生成树集合。
    • 如果加入边后会形成环路,(即在同一集合)则跳过该边。
  4. 重复步骤3,直到最小生成树集合中的边数等于图中顶点数减1,或者遍历完所有边。
  5. 最终得到的最小生成树集合即为所求的最小生成树。

Kruskal算法的核心思想是通过不断选择权重最小的边,并判断是否形成环路来构建最小生成树。它不需要事先知道图的连通性,而是通过边的选择来逐步连接图中的顶点,直到所有顶点都被连接为止。

需要注意的是,Kruskal算法适用于解决无向图的最小生成树问题,对于有向图则需要使用其他算法,如Prim算法。此外,Kruskal算法也可以处理带有边权重相同的情况。


二.模板题

P3366 【模板】最小生成树 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)


三.【AC】代码

#include<bits/stdc++.h>
#define maxn 200010
using namespace std;
inline int read(){int ans=0,f=1;char cc=getchar();while(cc<'0' || cc>'9'){if(cc=='-') f=-1;cc=getchar();}while(cc>='0' && cc<='9'){ans=(ans<<1)+(ans<<3)+(cc-'0');cc=getchar();}return ans*f;
}
int n,m,ans=0;
bool flag=0;
int fa[5010];
struct Edge{int u,v,w;
}edge[maxn];
bool cmp(Edge a,Edge b){return a.w<b.w;
}
inline int find(int x){return x==fa[x] ? x : fa[x]=find(fa[x]);
}
inline void merge(int x,int y){int fx=find(x),fy=find(y);fa[fx]=fy;
}
void kruskal(){sort(edge+1,edge+m+1,cmp);int cnt=0;for(int i=1;i<=m;i++){int x=edge[i].u,y=edge[i].v;if(find(x)==find(y)) continue;ans+=edge[i].w;merge(x,y);cnt++;if(cnt==n-1){flag=1;return;} }
}
int main(){//读入数据 n=read();m=read();for(int i=1;i<=m;i++){edge[i].u=read();edge[i].v=read();edge[i].w=read();}for(int i=1;i<=n;i++) fa[i]=i;//调用算法 kruskal();//输出结果if(flag) printf("%d",ans); else printf("orz");return 0;
}

http://www.hrbkazy.com/news/50230.html

相关文章:

  • 做网站运营用什么配置电脑网站快速排名上
  • 网站建设51jyoo青岛网络优化费用
  • 专业网站优化服务百度推广竞价是什么意思
  • 网站 做百度推广有没有效果百度搜索资源平台token
  • 美国企业黄页网站产品的网络推广要点
  • 网站顶部伸缩广告南阳网站seo
  • 淘宝开放平台怎么做淘宝客网站b站广告投放平台入口
  • 电子商务网站建设新手佛山网络公司 乐云seo
  • 企业百度网站怎么做如何网络媒体推广
  • wordpress修改固定链接重定向广东seo加盟
  • 城市分站cms网站推广软件免费版大全
  • 要建网站游戏推广怎么做
  • 在线ppt网站大数据营销案例
  • 谷歌推广网站建设营销培训心得体会
  • php 网站部署企业邮箱登录入口
  • php做网站还是linux长沙网络营销学校
  • 做动画 的 网站有哪些软件下载东莞关键词seo
  • 网络商城网站建设seo快速推广窍门大公开
  • 网站建设算什么专业今日的最新新闻
  • 西安市城乡建设委员会网站6外贸营销型网站制作
  • 关于做代购网站的纳税知识百度关键词优化
  • 给私人企业做网站推广yahoo搜索
  • 高端企业网站建站程序免费永久个人域名注册
  • 创新的龙岗网站建设网站建站哪家公司好
  • 网站开发工程师月薪网站开发从入门到实战
  • 邯郸有建网站吗哪个公司好些如何在百度发布广告信息
  • 房产网站开发文档推广一个产品有哪些方式
  • 做游戏ppt下载网站有哪些无锡seo公司哪家好
  • 郑州汉狮做网站的大公司2024年新闻摘抄十条
  • 专业公司做网站怎么做网站宣传