您好,登錄后才能下訂單哦!
這篇文章主要介紹C語言如何鄰接表建立圖,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!
代碼:
#include<stdio.h> #include<stdlib.h> #include<string.h> #include<stack> using namespace std; #define maxn 200 int v, e; //表結(jié)點 typedef struct _Enode { int ivex; //該邊所指向的節(jié)點位置 int value;//如果邊有權(quán)值的話,就對其賦值 struct _Enode* next_edge; //指向下一條邊 }ENode,*PENode; //頭結(jié)點 typedef struct _VNode { int data; ENode* fidt_edge; }VNode; //鄰接表 typedef struct _LGraph { int vex_num; //點的數(shù)量 int edg_num; //邊的數(shù)量 VNode vexs[maxn]; //一維數(shù)組存表頭節(jié)點 }LGraph; LGraph* create() { LGraph* pG; pG = (LGraph*)malloc(sizeof(LGraph)); memset(pG, 0, sizeof(LGraph)); pG->vex_num = v; //頂點數(shù) pG->edg_num = e; //邊數(shù) 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;//該邊指向的節(jié)點 // 頭插法建立 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;//該邊指向的節(jié)點 // 頭插法建立 p1->next_edge = pG->vexs[v1].fidt_edge; pG->vexs[v1].fidt_edge = p1; //另一條邊 ENode* p2 = (ENode*)malloc(sizeof(ENode)); //為新建的邊申請空間 p2->ivex = v1;//該邊指向的節(jié)點 // 頭插法建立 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; //表結(jié)點 typedef struct _Enode { int ivex; //該邊所指向的節(jié)點位置 struct _Enode* next_edge; //指向下一條邊 }ENode,*PENode; //頭結(jié)點 typedef struct _VNode { int data; int indegree;//記錄定點的入度 ENode* fidt_edge; }VNode; //鄰接表 typedef struct _LGraph { int vex_num; //點的數(shù)量 int edg_num; //邊的數(shù)量 VNode vexs[maxn]; //一維數(shù)組存表頭節(jié)點 }LGraph; LGraph* create() { LGraph* pG; pG = (LGraph*)malloc(sizeof(LGraph)); memset(pG, 0, sizeof(LGraph)); pG->vex_num = v; //頂點數(shù) pG->edg_num = e; //邊數(shù) 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;//該邊指向的節(jié)點 // 頭插法建立 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) //記錄各個頂點的入度 { //遍歷整個鄰接表,如果表結(jié)點的值為 i,則i對應(yīng)的頭結(jié)點的入度加1 p = pG->vexs[i].fidt_edge; //獲得其指向的第一條邊 while (p) { pG->vexs[p->ivex].indegree++; //該邊表存的位置對應(yīng)的頭結(jié)點的入度數(shù)量加1 p = p->next_edge; } } //將入度為0的壓入棧中 for (int i = 0; i < v; ++i) if (pG->vexs[i].indegree == 0)s.push(i); count = 0;//對輸出的頂點計數(shù) while (!s.empty()) { int k = s.top(); //取出 s.pop(); ++count; //與k節(jié)點相鄰的節(jié)點的入度減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語言如何鄰接表建立圖”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。