论坛登陆 用户名:  密 码:
设为首页  加入收藏
08年北京名校秋季招生
名牌院校免试入学宽进严出,突破考分限制,名校与你零距离,以下院校按报名先后顺序录取,24小时网上报名覆盖全国
  您现在的位置: 中国教育招生在线 >> IT >> 复习资料 >> IT正文
链表的C语言实现系列辅导:单链表的实现
 作者:佚名     2007-3-15 14:57:17        来源:不详  浏览次数:
    单链表的建立

  有了动态内存分配的基础,要实现链表就不难了。

  所谓链表,就是用一组任意的存储单元存储线性表元素的一种数据结构。链表又分为单链表、双向链表和循环链表等。我们先讲讲单链表。
所谓单链表,是指数据接点是单向排列的。一个单链表结点,其结构类型分为两部分:

  1、数据域:用来存储本身数据

  2、链域或称为指针域:用来存储下一个结点地址或者说指向其直接后继的指针。

  例:

typedef struct node
{
 char name[20];
 struct node *link;
}stud;

  这样就定义了一个单链表的结构,其中char name[20]是一个用来存储姓名的字符型数组,指针*link是一个用来存储其直接后继的指针。

  定义好了链表的结构之后,只要在程序运行的时候爱数据域中存储适当的数据,如有后继结点,则把链域指向其直接后继,若没有,则置为NULL。

  下面就来看一个建立带表头(若未说明,以下所指链表均带表头)的单链表的完整程序。

#include <stdio.h>
#include <malloc.h> /*包含动态内存分配函数的头文件*/
#define N 10 /*N为人数*/
typedef struct node
{
 char name[20];
 struct node *link;
}stud;
stud * creat(int n) /*建立单链表的函数,形参n为人数*/
{
 stud *p,*h,*s; /* *h保存表头结点的指针,*p指向当前结点的前一个结点,*s指向当前结点*/
 int i; /*计数器*/
 if((h=(stud *)malloc(sizeof(stud)))==NULL) /*分配空间并检测*/
 {
  printf("不能分配内存空间!");
  exit(0);
 }
 h->name[0]='\0'; /*把表头结点的数据域置空*/
 h->link=NULL; /*把表头结点的链域置空*/
 p=h; /*p指向表头结点*/
 for(i=0;i<n;i++)
 {
  if((s= (stud *) malloc(sizeof(stud)))==NULL) /*分配新存储空间并检测*/
  {
   printf("不能分配内存空间!");
   exit(0);
  }
  p->link=s; /*把s的地址赋给p所指向的结点的链域,这样就把p和s所指向的结点连接起来了*/
  printf("请输入第%d个人的姓名",i+1);
  scanf("%s",s->name); /*在当前结点s的数据域中存储姓名*/
  s->link=NULL;
  p=s;
 }
 return(h);
}
main()
{
 int number; /*保存人数的变量*/
 stud *head; /*head是保存单链表的表头结点地址的指针*/
 number=N;
 head=creat(number); /*把所新建的单链表表头地址赋给head*/
}  

  这样就写好了一个可以建立包含N个人姓名的单链表了。写动态内存分配的程序应注意,请尽量对分配是否成功进行检测。 
责任编辑:lss
  相关新闻
经典的C程序案例
VFP表转换成SQL Server表的方法
一名网管的CCIE考证亲历记
链表的C语言实现系列辅导:动态内存分配
Exchange Server 的CDO对象集合二
Exchange Server 的CDO对象集合一
Exchange Server 的CDO对象集合三
链表的C语言实现系列辅导:单链表的查找运算
Oracle中表的连接及其调整
详解Java中的指针、引用及对象的clone
链表的C语言实现系列辅导:单链表的查找运算
链表的C语言实现系列辅导:动态内存分配
Oracle中表的连接及其调整
一名网管的CCIE考证亲历记
Apusic应用服务器的ClassLoader结构
详解Java中的指针、引用及对象的clone
水晶报表的jsp实现(开发工具:bea weblogic workshop)
VFP表转换成SQL Server表的方法
经典的C程序案例
Exchange Server 的CDO对象集合一
  评论
现在有100人对本文发表评论
查看所有评论
 
推  荐
 
100本成功必读热销书
热门招生
  北京文理研修学院   前进大学
  北京明园大学   北京建设大学
  北京邮电大学世纪学院   北方工商管理学院
  联想软件定向委培班   香港数码动画学院
  青年企业管理研修学院   北京华夏管理学院
热门培训
网络化办公专家培训认证 电子科技大学软件学院
软件测试工程师培训认证 北大青鸟十大授权培训
IT硬件工程师培训认证班 北京环球雅思荷兰预科
JAVA开发工程师培训 潜能时代IT服务管理培训
网络信息化工程师培训 清华大学继续教育学院
论坛精选
 
有些细节是男人也该注意的风度!最容易读错的字
某强人手机里保存的30条短信 中国十大高薪职业
最感人的十大韩剧经典台词 嫁给工程师的N个理由
爆强!只有一句话的鬼故事 转贴教你如何做妖精
 女人一定要記住的話 女人最好别嫁给最爱的男人
城市联盟
 大连 上海 天津 广州 西安 深圳  天津  青岛  大连  福州  沈阳  青海  连云港  南京  吉林  厦门  威海  辽宁  呼和浩特
Copyright © 2006   www.edu999.com   All rights reserved. 中国教育招生在线  版权所有
北京市通信管理局[2004]字第552号函    京ICP证040442号