无向图的领接表

无向图的领接表。

#include <stdio.h>
#include <stdlib.h>
typedef struct EdgeNode{     // 边表结点 
	int adjvex;              // 领接点域,存储该顶点对应的下标             
	struct EdgeNode *next;   // 链域,指向下一个领接点 
}EdgeNode;

typedef struct VertexNode{    // 顶点表结点 
	int data;                 // 顶点域,存储顶点信息
	EdgeNode *firstedge;      // 边表头指针 	
}VertexNode;

typedef struct{
	VertexNode adjList[100];
	int numVertex,numEdges;   // 图中当前顶点数和边数 
}GraphAdjList;
void CreateALGraph(GraphAdjList *G)
{
	int i,j,k;
	EdgeNode *e;
	printf("请输入顶点数和边数:");
	scanf("%d%d",&G->numVertex,&G->numEdges);  // 读入顶点个数与边数 
	for(i=0;i<G->numVertex;i++)
	{
		printf("请输入第%d个顶点:",i);
		scanf("%d",&G->adjList[i].data);     // 读入各个顶点信息 
		G->adjList[i].firstedge=NULL;        // 将边表置为空表 
	}
	for(k=0;k<G->numEdges;k++)
	{
		printf("输入边(vi,vj)上的顶点下标:");   // 读入与边关联的顶点下标 
		scanf("%d%d",&i,&j);
		e=(EdgeNode *)malloc(sizeof(EdgeNode));    // 创建边表结点 
		e->adjvex=j;                             
		e->next=G->adjList[i].firstedge;
		G->adjList[i].firstedge=e;
		// 若是有向图,下面这个可以不要 
		e=(EdgeNode *)malloc(sizeof(EdgeNode));
		e->adjvex=i;
		e->next=G->adjList[j].firstedge;
		G->adjList[j].firstedge=e;				
	}
	for(i=0;i<G->numVertex;i++)
	{
		printf("与第%d个顶点相领接的顶点下标有:",i);
		while(G->adjList[i].firstedge!=NULL)
		{
			printf("%d ",G->adjList[i].firstedge->adjvex);
			G->adjList[i].firstedge=G->adjList[i].firstedge->next;
		}
		printf("\n");	
	}
}
int main()
{
	GraphAdjList G;
	CreateALGraph(&G);
}


  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值