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

电子版证件照免费制作微信小程序seo优化好做吗

电子版证件照免费制作微信小程序,seo优化好做吗,网络推广公司诈骗投诉,浙江 网站建设最小生成树概念 参考:什么是最小生成树? Minimum Spanning Tree 何为生成树? 生成树是指一个联通图的极小的连通子图,它包含了图中的所有n个顶点,并只有n-1条边(构成一棵树) 生成树的一些性…

最小生成树概念

参考:什么是最小生成树?

Minimum Spanning Tree

何为生成树?

生成树是指一个联通图的极小的连通子图,它包含了图中的所有n个顶点,并只有n-1条边(构成一棵树)
在这里插入图片描述
生成树的一些性质:

  • 一个连通图可以有多种生成树(如上图所示)
  • 生成树中不存在环
  • 任何一个边的加入都会使得生成树中出现环

何为最小生成树?

最小生成树是针对一个带权图来说的,就是指原图中能构成的所有生成树中,边权和最小的一颗生成树

对于下面的连通图:
在这里插入图片描述
可以有多种选取边(即构成了生成树的情况):
在这里插入图片描述
我们称权值和最小的树为最小生成树

最小生成树有什么意义呢?

接上图,如果我们需要在某城市之间修建道路,点与点之间的加权边就是两城市道路的维修费,如果我们想找到一种将所有城市都连通起来并且使得道路修建费用最小的一种方案,那么就要选择使用最小生成树。

最小生成树构建方法

两种方法都是基于贪心
有一点,其实我不太明白。“Kruskal算法维护的是边,所以不需要对于无向图存储两次边。Prim维护的是集合之间点的关系,因此需要对无向图存储两次边

克鲁斯卡尔算法(Kruskal)

算法思想

将所有的带权边按照权值从小到大排列,从最小的开始选择,如果加入该边后不会产生环,则加入,反之则不加入。直到已经选择了n-1条边。
这里不会产生环的判定比较困难,因此可以换一下想法:
就是只要选择的边的两端点不在同一连通块中即可。如下所示
在这里插入图片描述
使用并查集就可以检查联通问题了


#include<iostream>
#include<algorithm>using namespace std;const int N=2*1e5+10;int n,m;
int p[N];
int ans=0;//最终权值
int res=0;//已经放入的边数struct nn{int a;int b;int w;
}node[N];int cmp(nn a, nn b){return a.w<b.w;
}int find(int x){if(p[x]!=x) p[x]=find(p[x]);return p[x];
}int kruskal(){for(int i=1;i<=n;i++)p[i]=i;for(int i=1;i<=m;i++){//遍历m条边int a=node[i].a, b=node[i].b, w=node[i].w;a=find(a); b=find(b);if(a!=b){//如果不在一个联通图中p[a]=b;//连接两个点ans+=w;res++;}if(res==n-1){return res;}}return res;
}int main(){cin>>n>>m;for(int i=1;i<=m;i++){cin>>node[i].a>>node[i].b>>node[i].w;}sort(node+1,node+1+m,cmp);if(kruskal()==n-1)cout<<ans<<endl;elsecout<<"impossible"<<endl;return 0;
}

普里姆算法(Prim)

和kruskal算法(遍历边)不同的是,prim算法是对点进行遍历

算法思路

对于每个点,每次找到一个集合外的,距离该集合最近的点t。(该集合是一个已经确定了的连通块)
用点t更新集合外点到集合的距离,就是找集合外和t有连接的点,如果更小就更新,最后将点t放入集合中。(这里描述的不是很清楚)

st[j]==0&&(t==-1||dist[t]>dist[j]) 注意这里的判断,首先判断该点是否已经进入集合,然后再与上(t==-1和大小的或运算)


#include<iostream>
#include<algorithm>
#include<cstring>using namespace std;const int N=510,INF=0x3f3f3f3f;
int n,m;int g[N][N];//用于存储边
int dist[N];//点距离集合的距离
int st[N];//表示是否已经进入集合
int ans=0;int prim(){dist[1]=0;//强制一开始选择的点就是点1for(int i=1;i<=n;i++){//外层循环是指循环n次以遍历所有n个点int t=-1;for(int j=1;j<=n;j++){if(st[j]==0&&(t==-1||dist[t]>dist[j])){t=j;}  }//找到最短的dist,下标为tif(dist[t]==INF)    return INF;//说明没有点能够到达当前的集合ans+=dist[t];for(int j=1;j<=n;j++){if(st[j]==0&&j!=t){//更新所有集合外的点到该集合的距离dist[j]=min(dist[j],g[t][j]);}}st[t]=1;//将点加入集合}}int main(){cin>>n>>m;memset(g,0x3f,sizeof g);for(int i=1;i<=m;i++){int a,b,c;cin>>a>>b>>c;g[a][b]=g[b][a]=min(g[a][b],c);}memset(dist,0x3f,sizeof dist);if(prim()==INF)cout<<"impossible"<<endl;elsecout<<ans<<endl;return 0;
}
http://www.hkea.cn/news/545898/

相关文章:

  • 用阿里巴巴店铺做公司网站怎么样引擎搜索有哪些
  • 网页制作软件属于什么软件类别简述seo的优化流程
  • 网站建设 公司新闻谷歌排名网站优化
  • 怎样做自己的vip解析网站佛山外贸seo
  • 我的网站在百度搜不到了seo是什么职业做什么的
  • 网站私信界面国外网站seo免费
  • wordpress mysql类惠州网站seo
  • 为什么做网站必须要用域名举出最新的网络营销的案例
  • 电子请柬网站开发百度竞价推广登录入口
  • 网站设计与推广国际时事新闻2022最新
  • 柬埔寨网站开发营销技巧和营销方法
  • 网站建立价格长沙网站外包公司
  • 王建设医生个人网站免费google账号注册入口
  • 免费自建手机网站搜索引擎优化的方法包括
  • 甘肃省建设工程安全质量监督管理局网站官网拉新项目官方一手平台
  • 做电影网站赚钱武汉新闻最新消息
  • 做网站没有成本的方法上海百度分公司电话
  • 寺庙网站建设百度ai人工智能
  • 完成公司网站建设下载关键词推广软件
  • wordpress如何关闭网站下载app
  • WordPress小程序二次修改石家庄seo排名外包
  • 做百度关键词网站厦门seo外包
  • 泉州seo-泉州网站建设公司谷歌关键词搜索工具
  • 组织部网站建设方案行业关键词分类
  • 上海黄浦 网站制作中国搜索引擎排名2021
  • 手机网站建设 cms营销技巧和营销方法
  • 平顶山做网站优化微博搜索引擎优化
  • 网站如何做品牌宣传海报每日舆情信息报送
  • 做论坛网站需要多大空间seo推广招聘
  • 中国建设银行网站软件不限次数观看视频的app