C語(yǔ)言鄰接表建立圖詳解
更新時(shí)間:2021年08月25日 11:38:59 作者:落春只在無(wú)意間
這篇文章主要介紹了C語(yǔ)言鄰接表建立圖,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
有向圖
代碼:
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<stack>
using namespace std;
#define maxn 200
int v, e;
//表結(jié)點(diǎn)
typedef struct _Enode
{
int ivex; //該邊所指向的節(jié)點(diǎn)位置
int value;//如果邊有權(quán)值的話,就對(duì)其賦值
struct _Enode* next_edge; //指向下一條邊
}ENode,*PENode;
//頭結(jié)點(diǎn)
typedef struct _VNode
{
int data;
ENode* fidt_edge;
}VNode;
//鄰接表
typedef struct _LGraph
{
int vex_num; //點(diǎn)的數(shù)量
int edg_num; //邊的數(shù)量
VNode vexs[maxn]; //一維數(shù)組存表頭節(jié)點(diǎn)
}LGraph;
LGraph* create()
{
LGraph* pG;
pG = (LGraph*)malloc(sizeof(LGraph));
memset(pG, 0, sizeof(LGraph));
pG->vex_num = v; //頂點(diǎn)數(shù)
pG->edg_num = e; //邊數(shù)
for (int i = 0; i < v; ++i) //初始化定點(diǎn)表的指針域?yàn)榭?
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)); //為新建的邊申請(qǐng)空間
p1->ivex = v2;//該邊指向的節(jié)點(diǎn)
// 頭插法建立
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;
}
無(wú)向圖
在代碼的建立鏈表的地方變成
//建立鏈表
for (int i = 0; i < e; ++i)
{
int v1, v2;
scanf_s("%d%d", &v1, &v2);
ENode* p1 = (ENode*)malloc(sizeof(ENode)); //為新建的邊申請(qǐng)空間
p1->ivex = v2;//該邊指向的節(jié)點(diǎn)
// 頭插法建立
p1->next_edge = pG->vexs[v1].fidt_edge;
pG->vexs[v1].fidt_edge = p1;
//另一條邊
ENode* p2 = (ENode*)malloc(sizeof(ENode)); //為新建的邊申請(qǐng)空間
p2->ivex = v1;//該邊指向的節(jié)點(diǎn)
// 頭插法建立
p2->next_edge = pG->vexs[v2].fidt_edge;
pG->vexs[v2].fidt_edge = p2;
}
鄰接表存圖進(jìn)行拓?fù)渑判?/h2>
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<stack>
using namespace std;
#define maxn 200
int v, e;
//表結(jié)點(diǎn)
typedef struct _Enode
{
int ivex; //該邊所指向的節(jié)點(diǎn)位置
struct _Enode* next_edge; //指向下一條邊
}ENode,*PENode;
//頭結(jié)點(diǎn)
typedef struct _VNode
{
int data;
int indegree;//記錄定點(diǎn)的入度
ENode* fidt_edge;
}VNode;
//鄰接表
typedef struct _LGraph
{
int vex_num; //點(diǎn)的數(shù)量
int edg_num; //邊的數(shù)量
VNode vexs[maxn]; //一維數(shù)組存表頭節(jié)點(diǎn)
}LGraph;
LGraph* create()
{
LGraph* pG;
pG = (LGraph*)malloc(sizeof(LGraph));
memset(pG, 0, sizeof(LGraph));
pG->vex_num = v; //頂點(diǎn)數(shù)
pG->edg_num = e; //邊數(shù)
for (int i = 0; i < v; ++i) //初始化定點(diǎn)表的指針域?yàn)榭?
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)); //為新建的邊申請(qǐng)空間
p1->ivex = v2;//該邊指向的節(jié)點(diǎn)
// 頭插法建立
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) //記錄各個(gè)頂點(diǎn)的入度
{
//遍歷整個(gè)鄰接表,如果表結(jié)點(diǎn)的值為 i,則i對(duì)應(yīng)的頭結(jié)點(diǎn)的入度加1
p = pG->vexs[i].fidt_edge; //獲得其指向的第一條邊
while (p)
{
pG->vexs[p->ivex].indegree++; //該邊表存的位置對(duì)應(yīng)的頭結(jié)點(diǎn)的入度數(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;//對(duì)輸出的頂點(diǎn)計(jì)數(shù)
while (!s.empty())
{
int k = s.top(); //取出
s.pop();
++count;
//與k節(jié)點(diǎn)相鄰的節(jié)點(diǎn)的入度減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;
}
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<stack>
using namespace std;
#define maxn 200
int v, e;
//表結(jié)點(diǎn)
typedef struct _Enode
{
int ivex; //該邊所指向的節(jié)點(diǎn)位置
struct _Enode* next_edge; //指向下一條邊
}ENode,*PENode;
//頭結(jié)點(diǎn)
typedef struct _VNode
{
int data;
int indegree;//記錄定點(diǎn)的入度
ENode* fidt_edge;
}VNode;
//鄰接表
typedef struct _LGraph
{
int vex_num; //點(diǎn)的數(shù)量
int edg_num; //邊的數(shù)量
VNode vexs[maxn]; //一維數(shù)組存表頭節(jié)點(diǎn)
}LGraph;
LGraph* create()
{
LGraph* pG;
pG = (LGraph*)malloc(sizeof(LGraph));
memset(pG, 0, sizeof(LGraph));
pG->vex_num = v; //頂點(diǎn)數(shù)
pG->edg_num = e; //邊數(shù)
for (int i = 0; i < v; ++i) //初始化定點(diǎn)表的指針域?yàn)榭?
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)); //為新建的邊申請(qǐng)空間
p1->ivex = v2;//該邊指向的節(jié)點(diǎn)
// 頭插法建立
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) //記錄各個(gè)頂點(diǎn)的入度
{
//遍歷整個(gè)鄰接表,如果表結(jié)點(diǎn)的值為 i,則i對(duì)應(yīng)的頭結(jié)點(diǎn)的入度加1
p = pG->vexs[i].fidt_edge; //獲得其指向的第一條邊
while (p)
{
pG->vexs[p->ivex].indegree++; //該邊表存的位置對(duì)應(yīng)的頭結(jié)點(diǎn)的入度數(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;//對(duì)輸出的頂點(diǎn)計(jì)數(shù)
while (!s.empty())
{
int k = s.top(); //取出
s.pop();
++count;
//與k節(jié)點(diǎn)相鄰的節(jié)點(diǎn)的入度減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;
}
總結(jié)
本篇文章就到這里了,希望能給你帶來(lái)幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
C++ 中約瑟夫環(huán)替換計(jì)數(shù)器m(數(shù)組解決)
這篇文章主要介紹了C++ 中約瑟夫環(huán)替換計(jì)數(shù)器m(數(shù)組解決)的相關(guān)資料,需要的朋友可以參考下2017-05-05
OpenCV實(shí)現(xiàn)簡(jiǎn)單套索工具
這篇文章主要為大家詳細(xì)介紹了OpenCV實(shí)現(xiàn)簡(jiǎn)單套索工具,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-01-01
C語(yǔ)言版二值圖像統(tǒng)計(jì)連通區(qū)域
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言版二值圖像統(tǒng)計(jì)連通區(qū)域的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-01-01
C++中based for循環(huán)的實(shí)現(xiàn)
C++中的范圍for循環(huán)是一種簡(jiǎn)潔的遍歷容器的方法,本文主要介紹了C++中based for循環(huán)的實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下2025-02-02
C++ 中"priority_queue" 優(yōu)先級(jí)隊(duì)列實(shí)例詳解
這篇文章主要介紹了C++ 中"priority_queue" 優(yōu)先級(jí)隊(duì)列實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下2017-04-04
C++?折疊參數(shù)包詳解(悄然增強(qiáng)編程效率)
折疊參數(shù)就是一個(gè)參數(shù)包, 代表是多個(gè)未知,tuple元組就是一個(gè)折疊參數(shù)的使用,這篇文章主要介紹了C++?折疊參數(shù)包悄然增強(qiáng)編程效率,需要的朋友可以參考下2023-05-05

