IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> C++知识库 -> 邻接表建立图(c语言) -> 正文阅读

[C++知识库]邻接表建立图(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++知识库 最新文章
【C++】友元、嵌套类、异常、RTTI、类型转换
通讯录的思路与实现(C语言)
C++PrimerPlus 第七章 函数-C++的编程模块(
Problem C: 算法9-9~9-12:平衡二叉树的基本
MSVC C++ UTF-8编程
C++进阶 多态原理
简单string类c++实现
我的年度总结
【C语言】以深厚地基筑伟岸高楼-基础篇(六
c语言常见错误合集
上一篇文章      下一篇文章      查看所有文章
加:2021-08-25 23:42:00  更:2021-08-25 23:42:04 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/23 17:01:53-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码