日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

邻接表建立图(c语言)

發布時間:2025/3/19 编程问答 20 豆豆
生活随笔 收集整理的這篇文章主要介紹了 邻接表建立图(c语言) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

鄰接表建立圖

  • 有向圖
  • 無向圖
  • 鄰接表存圖進行拓撲排序

不得不說網上的真的是太亂了,看得我腦殼疼
自己寫的可以,感覺好的話可以當成模板。

有向圖

代碼:

#include<stdio.h> #include<stdlib.h> #include<string.h> #include<stack>using namespace std; #define maxn 200int 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 200int 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對應的頭結點的入度加1p = pG->vexs[i].fidt_edge; //獲得其指向的第一條邊while (p){pG->vexs[p->ivex].indegree++; //該邊表存的位置對應的頭結點的入度數量加1p = 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節點相鄰的節點的入度減1for (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");elseprintf("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语言)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。