亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

C語言如何鄰接表建立圖

發布時間:2021-08-25 13:24:50 來源:億速云 閱讀:153 作者:小新 欄目:開發技術

這篇文章主要介紹C語言如何鄰接表建立圖,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

有向圖

代碼:

#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語言如何鄰接表建立圖”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

海城市| 邵武市| 上饶县| 雷山县| 米脂县| 兖州市| 蒙城县| 深泽县| 龙南县| 双流县| 平遥县| 新密市| 察雅县| 元朗区| 高邑县| 霍州市| 望都县| 乌拉特后旗| 长宁区| 安图县| 镶黄旗| 大石桥市| 洛阳市| 新津县| 龙门县| 宝丰县| 广宁县| 图们市| 法库县| 荣昌县| 淮阳县| 玉田县| 古浪县| 石首市| 彭阳县| 邻水| 东乌珠穆沁旗| 门源| 新巴尔虎右旗| 舞钢市| 石嘴山市|