当前位置:  编程技术>c/c++/嵌入式

最小生成树算法C语言代码实例

    来源: 互联网  发布时间:2014-10-23

    本文导语:  在贪婪算法这一章提到了最小生成树的一些算法,首先是Kruskal算法,实现如下: MST.h 代码如下:#ifndef H_MST#define H_MST #define NODE node *#define G graph *#define MST edge ** /* the undirect graph start */typedef struct _node { char data; int flag; struct _no...

在贪婪算法这一章提到了最小生成树的一些算法,首先是Kruskal算法,实现如下:

MST.h

代码如下:

#ifndef H_MST
#define H_MST

#define NODE node *
#define G graph *
#define MST edge **

/* the undirect graph start */
typedef struct _node {
 char data;
 int flag;
 struct _node *parent;
} node;

typedef struct _edge {
 node *A;
 node *B;
 int w;
} edge;

typedef struct _graph {
 node **nodelist;
 int nodeLen;
 edge **edgelist;
 int edgeLen;
} graph;

/* the undirect graph end */

int kruskal(G , edge *[]);

int makeset(NODE);

int find(NODE , NODE);

int merge(NODE , NODE);

int comp(const void *, const void *);

#endif

MST.c

代码如下:

#include "mst.h"
#include
#include

int main(int argc, char *argv[])
{
 /* Construct the undirect connected graph */
 graph g;
 g.nodeLen = 6;
 g.edgeLen = 10;

 node node_a, node_b, node_c, node_d, node_e, node_f;
 edge edge_1, edge_2, edge_3, edge_4, edge_5, edge_6, edge_7, edge_8, edge_9, edge_10;

 node_a.data = 'a';
 node_a.flag = 0;
 node_a.parent = (node *)malloc(sizeof(node));
 node_b.data = 'b';
 node_b.flag = 0;
 node_b.parent = (node *)malloc(sizeof(node));
 node_c.data = 'c';
 node_c.flag = 0;
 node_c.parent = (node *)malloc(sizeof(node));
 node_d.data = 'd';
 node_d.flag = 0;
 node_d.parent = (node *)malloc(sizeof(node));
 node_e.data = 'e';
 node_e.flag = 0;
 node_e.parent = (node *)malloc(sizeof(node));
 node_f.data = 'f';
 node_f.flag = 0;
 node_f.parent = (node *)malloc(sizeof(node));

 edge_1.A = &node_a;
 edge_1.B = &node_b;
 edge_1.w = 5;

 edge_2.A = &node_a;
 edge_2.B = &node_c;
 edge_2.w = 6;

 edge_3.A = &node_a;
 edge_3.B = &node_d;
 edge_3.w = 4;

 edge_4.A = &node_b;
 edge_4.B = &node_c;
 edge_4.w = 1;

 edge_5.A = &node_b;
 edge_5.B = &node_d;
 edge_5.w = 2;

 edge_6.A = &node_c;
 edge_6.B = &node_d;
 edge_6.w = 2;

 edge_7.A = &node_c;
 edge_7.B = &node_e;
 edge_7.w = 5;

 edge_8.A = &node_c;
 edge_8.B = &node_f;
 edge_8.w = 3;

 edge_9.A = &node_d;
 edge_9.B = &node_f;
 edge_9.w = 4;

 edge_10.A = &node_e;
 edge_10.B = &node_f;
 edge_10.w = 4;

 node **nodelist;
 nodelist = (node **)malloc(sizeof(node *) * g.nodeLen);
 edge **edgelist;
 edgelist = (edge **)malloc(sizeof(edge *) * g.edgeLen);

 nodelist[0] = &node_a;
 nodelist[1] = &node_b;
 nodelist[2] = &node_c;
 nodelist[3] = &node_d;
 nodelist[4] = &node_e;
 nodelist[5] = &node_f;

 edgelist[0] = &edge_1;
 edgelist[1] = &edge_2;
 edgelist[2] = &edge_3;
 edgelist[3] = &edge_4;
 edgelist[4] = &edge_5;
 edgelist[5] = &edge_6;
 edgelist[6] = &edge_7;
 edgelist[7] = &edge_8;
 edgelist[8] = &edge_9;
 edgelist[9] = &edge_10;

 g.nodelist = nodelist;
 g.edgelist = edgelist;

 edge *X[g.nodeLen-1];

 int e = 0;
 while (e < g.edgeLen)
 {
  printf("%c-%c %dn", g.edgelist[e]->A->data, g.edgelist[e]->B->data, g.edgelist[e]->w);
  e++;
 }

 printf("------------------------------------------------------n");

 kruskal(&g, X);

 e = 0;
 while (e < (g.nodeLen-1))
 {
  printf("%c-%c %dn", X[e]->A->data, X[e]->B->data, X[e]->w);
  e++;
 }
}

int kruskal(G g, edge *pX[])
{
 int i, j;

 /* Initially every disjoint set have one node */
 for (i = 0; i < g->nodeLen; i++)
  makeset(g->nodelist[i]);

 /* sort the edgelist */
 qsort(g->edgelist, g->edgeLen, sizeof(edge *), comp);

 int e = 0;
 while (e < g->edgeLen)
 {
  printf("%c-%c %dn", g->edgelist[e]->A->data, g->edgelist[e]->B->data, g->edgelist[e]->w);
  e++;
 }

 printf("------------------------------------------------------n");

 node da, db;
 da.parent = (node *)malloc(sizeof(node));
 db.parent = (node *)malloc(sizeof(node));

 for (j = 0; j < g->edgeLen; j++)
 {
  find(g->edgelist[j]->A, &da);
  find(g->edgelist[j]->B, &db);

  if (da.data != db.data)
  {
   merge(g->edgelist[j]->A, g->edgelist[j]->B);
   *pX++ = g->edgelist[j];
  }
 }
}

int makeset(NODE n)
{
 n->parent = n;
}

int find(NODE n, NODE ds)
{
 if (n->parent == n)
 {
  ds->data = n->data;
  ds->flag = 1;
  ds->parent = n->parent;
 }

 if (n->parent != n)
  find(n->parent, ds);
}

int merge(NODE da, NODE db)
{
 if (da->flag)
  db->parent = da;
 else
  da->parent = db;
}

int comp(const void *ea, const void *eb)
{
 if ((*(edge **)ea)->w > (*(edge **)eb)->w) return 1;
 else if ((*(edge **)ea)->w == (*(edge **)eb)->w ) return 0;
 else return -1;
}

在实现这个算法的时候,真正体会到了测试的重要性。程序能成功编译只是完成了一小部分,必须经过反复的测试才能发布。


    
 
 

您可能感兴趣的文章:

  • 如何用c实现生成一个类似windows下uuid的全局唯一串的算法
  • 有没有用过 JCE 的朋友,生成x.509证书,有没有免费算法,用哪家的比较好,给出示例代码!
  • php微博短网址算法 php生成短网址的实现代码
  • php生成数组与php全组合算法
  • php生成数组的使用示例 php全组合算法
  • python实现的生成随机迷宫算法核心代码分享(含游戏完整代码)
  • 纯C语言:贪心Prim算法生成树问题源码分享
  • 史上最全的java随机数生成算法分享
  • 如何用程序生成一个本地机器上一个类的实例?
  • C#生成随机字符串的实例
  • php生成excel列序号代码实例
  • C#生成不重复随机数列表实例
  • php生成透明背景图片实例
  • 高分火速求解,请在线朋友回答:java自定义类怎样生成实例数组?( className[] N=new className[X];怎么不行?)
  • ******"Servlet根据JSP视图的需求生成JavaBeans的实例并输出给JSP环境"如何实现上面这句话的效果??*******
  • 深入理解Java对象实例生成的例子
  • PHP接收二进制流并生成文件(实例)
  • C#生成单页静态页简单实例
  • php生成目录树实例代码
  • 请问怎么才能使一个类只生成一个实例?
  • PHP生成柱状图实例代码
  • c#生成缩略图不失真的方法实例分享
  • python生成日历实例解析
  • php 柱状图生成的简单例子 jpgraph类库实例
  • C++生成dll和调用dll的方法实例
  • PHP生成短网址的3种方法代码实例
  • Python生成验证码实例
  • php调用google接口生成二维码实例
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • PDF生成标记语言 PDML
  • C语言文档生成工具 GTK-Doc
  • 请问有什么工具可以将C语言的注释生成文档吗?
  • c语言生成随机uuid编码示例
  • c语言生成随机数的方法(获得一组不同的随机数)
  • 关于editplus的使用,编译完生成.class后,我又编写了html来执行applet,将其保存,如何经ie解释打开(直接在editplus上操作)不是显示html语言呀
  • 怎么通过C语言自动生成MAC地址
  • JSP中如何动态生成SQL语言?
  • C语言中堆空间的生成与释放详解
  • 如何用C语言生成简单格式的xml
  • 使用c语言生成随机数的示例分享
  • linux c下利用srand和rand函数生成随机字符串
  • 用JBuilder能将java程序生成exe可执行文件吗?如何生成?
  • Linux下c基于openssl生成MD5的函数
  • 我想问一下,java生成的.class文件能不能通过某种工具生成.exe文件?
  • c#如何生成Excel(.xls和.xlsx)文件
  • 高分求jsp中动态生成图片的相关资料、生成svg格式和pdf格式的资料,不够再加分
  • linux下利用(cat,strings,head,sed)命令生成随机字符串
  • 如何使用arm-uclibc-gcc将.c文件编译生成.a,将.c文件编译生成.cgi?
  • php中session_id()函数详细介绍,会话id生成过程及session id长度
  • 如何指定用javac编译生成类的存放路径。(最好不要告诉我再生成之后再把文件流重新到出这种)
  • linux c 生成随机数srand函数和rand函数介绍及代码示例
  • QT Designer生成的代码不能生成可执行程序
  • ORACLE中DBMS_RANDOM随机数生成包
  • 需要从数据库中动态生成的页面是该在SERVLET输出生成,还是应该在JSP编码实现?
  • Linux下c/c++开发之程序崩溃(Segment fault)时内核转储文件(core dump)生成设置方法
  • java生成字母数字组合的随机数示例 java生成随机数
  • 请问我用程序如何编辑Adobe Acrobat 5.0的pdf文件(生成报表)啊?或者如何才能将已生成的execl报表转换成pdf格式?
  • 请问用POI生成Excel文件时,怎么能生成边框线条等?
  • php生成短网址 仿微博短网址生成代码
  • 在JB自己生成的EJB客户端的测试代码中都会自动生成,象String url = "t3://localhost:7001";这样的,请问:


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3