电话:0731-83595998
导航

2011年软考程序员考试复习笔试知识点整理(11)3

来源: 2017-10-20 14:15

  最小生成树算法之Kruskal算法:

  算法思想:每次找最小的边,如果在已有的森林中加入该边后会形成回路,则舍弃,否则加入然后合并森林

  n:点的个数;

  edge_cnt:边的个数

  edge[]:保存边的数组

  edge_arr:保存选择边的数组,可选功能

  */

  template

  TMST_Kruskal(const int & n, const int & edge_cnt,Edge edge[], Edge* edge_arr = NULL)

  {

  T ans=0;

  int i,x,y,p[N],cnt=0;

  memset(p,-1,sizeof(p));

  sort(edge,edge+edge_cnt);

  for(i=0;i

  {

  x=FindSet(p,edge[i].from);

  y=FindSet(p,edge[i].to);

  if(x!=y)

  {

  UnionSet(p,x,y);

  ans+=edge[i].cost;

  if(edge_arr)

  edge_arr[cnt]=edge[i];

  cnt++;

  if(cnt==n-1)

  return ans;

  }

  }

  return -1;

  

编辑推荐:

下载Word文档

温馨提示:因考试政策、内容不断变化与调整,长理培训网站提供的以上信息仅供参考,如有异议,请考生以权威部门公布的内容为准! (责任编辑:长理培训)

网络课程 新人注册送三重礼

已有 22658 名学员学习以下课程通过考试

网友评论(共0条评论)

请自觉遵守互联网相关政策法规,评论内容只代表网友观点!

最新评论

点击加载更多评论>>

精品课程

更多
10781人学习

免费试听更多

相关推荐
图书更多+
  • 电网书籍
  • 财会书籍
  • 其它工学书籍
拼团课程更多+
  • 电气拼团课程
  • 财会拼团课程
  • 其它工学拼团
热门排行

长理培训客户端 资讯,试题,视频一手掌握

去 App Store 免费下载 iOS 客户端