图是一种重要而且相对复杂的数据结构,在实际编程中非常有用。邻接表是图的主要表示形式之一,是一种链接表表示方法。
#include
#include
#define MAX 10//令图的最大顶点个数为10
typedef struct node//边表结点(弧)
{
int adjvex;//相连顶点的编号
int weight;//边权
struct node *pnext;//指向下一个边表结点
}edgenode;
typedef struct vertexnode//顶点表结点
{
int adjvex;//顶点号
edgenode *pfirst;//边表头指针
}vertexnode;
typedef vertexnode adj_list[MAX]; //表头数组
typedef struct adjlist_graph//图的邻接表结构
{
int cnt_edges; //边数
int cnt_nodes; //顶点数
adj_list adjlist;//图的邻接表头
}adjlist_graph;
void create_graph(adjlist_graph* graph)//以邻接表方式创建图
{
edgenode* pnewnode;//新的边表结点
int i,j,k;
printf("输入图的顶点数和边数:\n");
scanf("%d%d",&graph->cnt_nodes,&graph->cnt_edges);