C语言邻接表建立图详解
更新时间:2021年8月25日 16:00 点击:1935
有向图
代码:
#include<stdio.h> #include<stdlib.h> #include<string.h> #include<stack> using namespace std; #define maxn 200 int v, e; //表结点 typedef struct _Enode { int ivex; //该边所指向的节点位置 int value;//如果边有权值的话,就对其赋值 struct _Enode* next_edge; //指向下一条边 }ENode,*PENode; //头结点 typedef struct _VNode { int data; ENode* fidt_edge; }VNode; //邻接表 typedef struct _LGraph { int vex_num; //点的数量 int edg_num; //边的数量 VNode vexs[maxn]; //一维数组存表头节点 }LGraph; LGraph* create() { LGraph* pG; pG = (LGraph*)malloc(sizeof(LGraph)); memset(pG, 0, sizeof(LGraph)); pG->vex_num = v; //顶点数 pG->edg_num = e; //边数 for (int i = 0; i < v; ++i) //初始化定点表的指针域为空 pG->vexs[i].fidt_edge = NULL; //建立链表 for (int i = 0; i < e; ++i) { int v1, v2; scanf_s("%d%d", &v1, &v2); ENode* p1 = (ENode*)malloc(sizeof(ENode)); //为新建的边申请空间 p1->ivex = v2;//该边指向的节点 // 头插法建立 p1->next_edge = pG->vexs[v1].fidt_edge; pG->vexs[v1].fidt_edge = p1; } return pG; } int main() { while (~scanf_s("%d%d", &v, &e)) { if (v == 0 && e == 0) break; LGraph* pG; pG = create(); } return 0; }
无向图
在代码的建立链表的地方变成
//建立链表 for (int i = 0; i < e; ++i) { int v1, v2; scanf_s("%d%d", &v1, &v2); ENode* p1 = (ENode*)malloc(sizeof(ENode)); //为新建的边申请空间 p1->ivex = v2;//该边指向的节点 // 头插法建立 p1->next_edge = pG->vexs[v1].fidt_edge; pG->vexs[v1].fidt_edge = p1; //另一条边 ENode* p2 = (ENode*)malloc(sizeof(ENode)); //为新建的边申请空间 p2->ivex = v1;//该边指向的节点 // 头插法建立 p2->next_edge = pG->vexs[v2].fidt_edge; pG->vexs[v2].fidt_edge = p2; }
邻接表存图进行拓扑排序
#include<stdio.h> #include<stdlib.h> #include<string.h> #include<stack> using namespace std; #define maxn 200 int v, e; //表结点 typedef struct _Enode { int ivex; //该边所指向的节点位置 struct _Enode* next_edge; //指向下一条边 }ENode,*PENode; //头结点 typedef struct _VNode { int data; int indegree;//记录定点的入度 ENode* fidt_edge; }VNode; //邻接表 typedef struct _LGraph { int vex_num; //点的数量 int edg_num; //边的数量 VNode vexs[maxn]; //一维数组存表头节点 }LGraph; LGraph* create() { LGraph* pG; pG = (LGraph*)malloc(sizeof(LGraph)); memset(pG, 0, sizeof(LGraph)); pG->vex_num = v; //顶点数 pG->edg_num = e; //边数 for (int i = 0; i < v; ++i) //初始化定点表的指针域为空 pG->vexs[i].fidt_edge = NULL; for (int i = 0; i < e; ++i) { int v1, v2; scanf_s("%d%d", &v1, &v2); ENode* p1 = (ENode*)malloc(sizeof(ENode)); //为新建的边申请空间 p1->ivex = v2;//该边指向的节点 // 头插法建立 p1->next_edge = pG->vexs[v1].fidt_edge; pG->vexs[v1].fidt_edge = p1; } return pG; } void TopSort(LGraph* pG) { stack<int>s; int count, k, i; ENode* p; for (int i = 0; i < v; ++i) //记录各个顶点的入度 { //遍历整个邻接表,如果表结点的值为 i,则i对应的头结点的入度加1 p = pG->vexs[i].fidt_edge; //获得其指向的第一条边 while (p) { pG->vexs[p->ivex].indegree++; //该边表存的位置对应的头结点的入度数量加1 p = p->next_edge; } } //将入度为0的压入栈中 for (int i = 0; i < v; ++i) if (pG->vexs[i].indegree == 0)s.push(i); count = 0;//对输出的顶点计数 while (!s.empty()) { int k = s.top(); //取出 s.pop(); ++count; //与k节点相邻的节点的入度减1 for (p = pG->vexs[k].fidt_edge; p; p = p->next_edge) { int to; to = p->ivex; pG->vexs[to].indegree--; //减为0的话就压入栈中 if (pG->vexs[to].indegree == 0) s.push(to); } } if (count < pG->vex_num) printf("NO\n"); else printf("YES\n"); } int main() { while (~scanf_s("%d%d", &v, &e)) { if (v == 0 && e == 0) break; LGraph* pG; pG = create(); TopSort(pG); } return 0; }
总结
本篇文章就到这里了,希望能给你带来帮助,也希望您能够多多关注猪先飞的更多内容!
相关文章
- 这篇文章主要为大家详细介绍了C语言实现放烟花的程序,有音乐播放,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2021-02-23
- 本篇文章主要介绍C语言中char的知识,并附有代码实例,以便大家在学习的时候更好的理解,有需要的可以看一下...2020-04-25
- 这篇文章主要介绍了详解如何将c语言文件打包成exe可执行程序,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-02-25
- free函数是释放之前某一次malloc函数申请的空间,而且只是释放空间,并不改变指针的值。下面我们就来详细探讨下...2020-04-25
- 这篇文章主要介绍了C语言中计算正弦的相关函数总结,包括正弦和双曲线正弦以及反正弦的函数,需要的朋友可以参考下...2020-04-25
详解C语言中的rename()函数和remove()函数的使用方法
这篇文章主要介绍了详解C语言中的rename()函数和remove()函数的使用方法,是C语言入门学习中的基础知识,需要的朋友可以参考下...2020-04-25- 这篇文章主要介绍了C语言中求和、计算平均值、方差和标准差的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-12-10
- 本篇文章主要讲解C语言 基本语法,这里提供简单的示例和代码来详细讲解C语言的基本语法,开始学习C语言的朋友可以看一下,希望能够给你带来帮助...2021-09-18
- 这篇文章主要介绍了C语言中send()函数和sendto()函数的使用方法,是C语言入门学习中的基础知识,需要的朋友可以参考下...2020-04-25
- 今天小编就为大家分享一篇C语言实现从文件读入一个3*3数组,并计算每行的平均值,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-04-25
- 这篇文章主要介绍了使用C语言操作文件的基本函数整理,包括创建和打开以及关闭文件的操作方法,需要的朋友可以参考下...2020-04-25
- 这篇文章主要介绍了C语言中memcpy 函数的用法详解的相关资料,需要的朋友可以参考下...2020-04-25
- 这篇文章主要介绍了C语言中查找字符在字符串中出现的位置的方法,分别是strchr()函数和strrchr()函数的使用,需要的朋友可以参考下...2020-04-25
- 很多同学在学习c语言的时候是不是会碰到a++和++a都有甚么作用啊。今天我们就来探讨下...2020-04-25
- 下面小编就为大家带来一篇C语言实现时间戳转日期的算法(推荐)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧...2020-04-25
- 这篇文章主要对C语言中const关键字的用法进行了详细的分析介绍,需要的朋友可以参考下...2020-04-25
- 这篇文章主要介绍了C语言之整数划分问题(递归法)实例代码的相关资料,需要的朋友可以参考下...2020-04-25
- 本文给大家简单介绍下c实现linux下的数据库备份的方法和具体的源码,十分的实用,有需要的小伙伴可以参考下。...2020-04-25
C语言正则表达式详解 regcomp() regexec() regfree()用法详解
C语言处理正则表达式常用的函数有regcomp()、regexec()、regfree()和regerror(),这里就为大家介绍一下,需要的朋友可以参考一下啊...2020-04-25- 这篇文章主要介绍了c语言实现找最大值最小值位置查找,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-02-04