图的邻接表表示法(C语言)

图的邻接表表示法(C语言)邻接表邻接表数据结构类型如下 defineMaxVer 边表 intadjvex node next EdgeNode typedefstruc 顶点表 intvertex EdgeNode edgenext VertexNode ty

邻接表

邻接表结构
邻接表数据结构类型如下:

#define MaxVertices 100 typedef struct node{ //边表 int adjvex; node* next; }EdgeNode; typedef struct{ //顶点表 int vertex; EdgeNode* edgenext; }VertexNode; typedef VertexNode AdjList[MaxVertices];//顶点表数组 typedef struct{ AdjList adjlist; int n,e; }AdjMatrix; 

注:边表为链表结构,插入元素有头插法和尾插法两种,这里以头插法为例。


邻接表生成函数:

void CreateGraph(AdjMatrix* G) { int i,j,k,w,v; EdgeNode *s; printf("输入顶点数和边数(中间以空格分开):"); scanf("%d%d",&G->n,&G->e); printf("建立顶点表\n"); for (i=0;i 
   
     n;i++) { //fflush(stdin); //如果 stream 指向输入流(如 stdin),那么 fflush 函数的行为是不确定的。 //故而使用 fflush(stdin) 是不正确的。 getchar(); printf("请输入第%d个顶点的信息:",i+1); G->adjlist[i].vertex=getchar(); G->adjlist[i].edgenext=NULL; } //前插法 printf("建立边表\n"); for (k=0;k 
    
      e;k++) { printf("输入有连接的顶点序号:"); scanf("%d%d",&i,&j); i-=1;j-=1; //① //对于直接相连的进行编入(即对输入“0 1”时,在0对应的边表中编入1) s=(EdgeNode*)malloc(sizeof(EdgeNode)); s->adjvex=j;//边表赋值 s->next=G->adjlist[i].edgenext; G->adjlist[i].edgenext=s; //对于间接相连的进行编入(即对输入“0 1”时,在1对应的边表中编入0) s=(EdgeNode*)malloc(sizeof(EdgeNode)); s->adjvex=i; s->next=G->adjlist[j].edgenext; G->adjlist[j].edgenext=s; } } 
     
   

邻接表打印函数:

void DispGraph(AdjMatrix *G) { int i; for (i=0;i 
   
     n;i++) { printf("%d->",i+1); while(1) { if(G->adjlist[i].edgenext==NULL) { printf("^"); break; } printf("%d->",G->adjlist[i].edgenext->adjvex+1); //② G->adjlist[i].edgenext=G->adjlist[i].edgenext->next; } printf("\n"); } } 
   

注:①②处是由于边表的顺序是对应的是顶点表数组的顺序,所以起始数组为G->adjlist[0],但是按照人们的输入习惯,我们从1开始,所以对于每个输入的i,j进行减1处理存储,再对于输出的G->adjlist[i].edgenext->adjvex进行加1处理,保证输入输出的统一性


具体代码实现:

#include 
    
      #include 
     
       #define MaxVertices 100 typedef struct node{ //边表 int adjvex; node* next; }EdgeNode; typedef struct{ //顶点表 int vertex; EdgeNode* edgenext; }VertexNode; typedef VertexNode AdjList[MaxVertices]; typedef struct{ AdjList adjlist; int n,e; }AdjMatrix; void CreateGraph(AdjMatrix* G) { int i,j,k,w,v; EdgeNode *s; printf("输入顶点数和边数(中间以空格分开):"); scanf("%d%d",&G->n,&G->e); printf("建立顶点表\n"); for (i=0;i 
      
        n;i++) { //fflush(stdin); //如果 stream 指向输入流(如 stdin),那么 fflush 函数的行为是不确定的。 //故而使用 fflush(stdin) 是不正确的。 getchar(); printf("请输入第%d个顶点的信息:",i+1); G->adjlist[i].vertex=getchar(); G->adjlist[i].edgenext=NULL; } //前插法 printf("建立边表\n"); for (k=0;k 
       
         e;k++) { printf("输入有连接的顶点序号:"); scanf("%d%d",&i,&j); i-=1;j-=1;//① //对于直接相连的进行编入(即对输入“0 1”时,在0对应的边表中编入1) s=(EdgeNode*)malloc(sizeof(EdgeNode)); s->adjvex=j;//边表赋值 s->next=G->adjlist[i].edgenext; G->adjlist[i].edgenext=s; //对于间接相连的进行编入(即对输入“0 1”时,在1对应的边表中编入0) s=(EdgeNode*)malloc(sizeof(EdgeNode)); s->adjvex=i; s->next=G->adjlist[j].edgenext; G->adjlist[j].edgenext=s; } } void DispGraph(AdjMatrix *G) { int i; for (i=0;i 
        
          n;i++) { printf("%d->",i+1); while(1) { if(G->adjlist[i].edgenext==NULL) { printf("^"); break; } printf("%d->",G->adjlist[i].edgenext->adjvex+1); //② G->adjlist[i].edgenext=G->adjlist[i].edgenext->next; } printf("\n"); } } int main() { AdjMatrix* G= (AdjMatrix*)malloc(sizeof(AdjMatrix)); CreateGraph(G); DispGraph(G); } 
         
        
       
      
    
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/220932.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月17日 下午7:19
下一篇 2026年3月17日 下午7:19


相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号