图是一种重要而且相对复杂的数据结构,在实际编程中非常有用。邻接表是图的主要表示形式之一,是一种链接表表示方法。

#include<stdio.h>

#include<stdlib.h>

#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);

printf("图的顶点有%d个,边数有%d个\n",

graph->cnt_nodes,graph->cnt_edges);

for(i=0;i<graph->cnt_nodes;i++)//初始化图的邻接表顶点

{

graph->adjlist[i].adjvex=i;

graph->adjlist[i].pfirst=NULL;

}

for(k=0;k<graph->cnt_edges;k++)//循环输入图各条边

{                              //无向图情形

printf("输入一条新的边:\n");

scanf("%d%d",&i,&j);

pnewnode=(edgenode*)malloc(sizeof(edgenode));

pnewnode->adjvex=j;

pnewnode->weight=0;

pnewnode->pnext=graph->adjlist[i].pfirst;

graph->adjlist[i].pfirst=pnewnode;

//无向图情形,具有对称性

pnewnode=(edgenode*)malloc(sizeof(edgenode));

pnewnode->adjvex=i;

pnewnode->weight=0;

pnewnode->pnext=graph->adjlist[j].pfirst;

graph->adjlist[j].pfirst=pnewnode;

}

}

void show_adjlist_graph(adjlist_graph* graph)//显示图中的顶点及其相关联的所有边

{

int i;

edgenode* pnode;

for(i=0;i<graph->cnt_nodes;i++)

{

pnode=graph->adjlist[i].pfirst;

printf("\n顶点编号%d:",graph->adjlist[i].adjvex);

while(pnode!=NULL)

{

printf(" 边:%d<->%d ",graph->adjlist[i].adjvex,pnode->adjvex);

pnode=pnode->pnext;

}

printf("\n");

}

}

int main(void)

{

adjlist_graph *pgraph;

pgraph=(adjlist_graph*)malloc(sizeof(adjlist_graph));

create_graph(pgraph);

show_adjlist_graph(pgraph);

}

图的建立——邻接表表示(C语言+VC6.0平台)的更多相关文章

  1. 图的建立——邻接矩阵表示(C语言+VC6.0平台)

    图的邻接矩阵表示及其建立(无向图) #include <stdio.h> #include <stdlib.h> typedef char VertexType;        ...

  2. 常用排序算法之——快速排序(C语言+VC6.0平台)

    经典排序算法中快速排序具有较好的效率,但其实现思路相对较难理解. #include<stdio.h> int partition(int num[],int low,int high) / ...

  3. 常用排序算法之——选择排序(C语言+VC6.0平台)

    选择排序是另一种经典排序算法,核心思想是:在一趟找最小(大)数的过程中,先假设待排数据中的第一个数据即为最小(大)数据,然后循环将其他数据与该数据比较,每次比较时若小于该数据则让新数据成为最小(大)数 ...

  4. 图->存储结构->邻接表

    文字描述 邻接表是图的一种链式存储结构.在邻接表中,对图中每个顶点建立一个单链表,第i个单链表的结点表示依附顶点vi的边(对有向图是指以顶点vi为尾的弧).单链表中的每个结点由3个域组成,其中邻接点域 ...

  5. 数据结构之---C语言实现图的邻接表存储表示

    // 图的数组(邻接矩阵)存储表示 #include <stdio.h> #include <stdlib.h> #include <string.h> #defi ...

  6. 邻接表有向图(一)之 C语言详解

    本章介绍邻接表有向图.在"图的理论基础"中已经对图进行了理论介绍,这里就不再对图的概念进行重复说明了.和以往一样,本文会先给出C语言的实现:后续再分别给出C++和Java版本的实现 ...

  7. 邻接表无向图(一)之 C语言详解

    本章介绍邻接表无向图.在"图的理论基础"中已经对图进行了理论介绍,这里就不再对图的概念进行重复说明了.和以往一样,本文会先给出C语言的实现:后续再分别给出C++和Java版本的实现 ...

  8. 图->存储结构->邻接多重表

    文字描述 邻接多重表是无向图的另一种链式存储结构. 虽然邻接表是无向图的一种很有效的存储结构,在邻接表中容易求得顶点和边的各种信息. 但是,在邻接表中每一条边(vi,vj)有两个结点,分别在第i个和第 ...

  9. c_数据结构_图_邻接表

    课程设计------邻接表 图的遍历实现课程设计:https://files.cnblogs.com/files/Vera-y/图的遍历_课程设计.zip #include<stdio.h> ...

随机推荐

  1. poj1797 - Heavy Transportation(最大边,最短路变形spfa)

    题目大意: 给你以T, 代表T组测试数据,一个n代表有n个点, 一个m代表有m条边, 每条边有三个参数,a,b,c表示从a到b的这条路上最大的承受重量是c, 让你找出一条线路,要求出在这条线路上的最小 ...

  2. 【转】MTK Android Driver知识大全

    原文网址:http://www.cnblogs.com/biglucky/p/4413797.html 一.Display 1.lcm 相关概念1.1) MIPI接口:一共有三种接口:DBI(也做CP ...

  3. Matlab:回归分析(1)

    1.多元线性回归 %数据的输入 x = [ ]; y = [ ]; %转换为列向量 X = [ones(,) x']; Y = y'; %回归分析及检验 [b, bint, r, rint, stat ...

  4. Java学习日记-11 集合(1)

    Collection接口集合中存储的只是对象的引用,不是对象本身. 1.ArrayList<E>类1.1ArrayList和Collection的关系 public interface L ...

  5. M - Jamie's Contact Groups - poj 2289(二分图多重匹配)

    题意:某个人通讯录有很多人,现在他想把这个人分组,给的数据是可以把这个人分在那些组里面,现在他想知道分组后,人最多的那个组至少有多少人. 分析:因为没有给组限制有多少人,可以使用二分求出来最小的那个, ...

  6. 同时安装Xcode6和Xcode7导致出现N多UUID 模拟器解决办法

    [摘要:1.完整退出Xcode 和 摹拟器 2.末端中输进以下两居指令 $ sudo killall -9 com.apple.CoreSimulator.CoreSimulatorService$ ...

  7. js中方法类型比较

    参考链接 http://bbs.csdn.net/topics/390775296/ function People(name){this.name=name;//对象方法this.Introduce ...

  8. ehcache报错ERROR n.s.e.store.disk.DiskStorageFactory - Disk Write的解决办法

    23:53:44 ERROR n.s.e.store.disk.DiskStorageFactory - Disk Write of com.koal.**.**.**.**.**.***Impl$$ ...

  9. POJ3080:Blue Jeans

    Description The Genographic Project is a research partnership between IBM and The National Geographi ...

  10. 跟Google学习Android开发-起始篇-用碎片构建一个动态的用户界面(3)

    4.3 构建一个灵活的用户界面 当设计你的应用程序要支持大范围的屏幕尺寸时,你可以在不同的布局配置中重用碎片,来根据可用的屏幕空间优化用户体验. 例如,在手持设备上,它可能是适应来在一个单窗格用户界面 ...