当前位置:首页 > 全部子站 > IT > 水平考试

C语言初学者入门知识之结构体3 3

来源:长理培训发布时间:2017-10-20 13:08:08

   前两个成员项组成数据域,后一个成员项next构成指针域,它是一个指向stu类型结构的指针变量。链表的基本操作对链表的主要操作有以下几种:

  1.建立链表;

  2.结构的查找与输出;

  3.插入一个结点;

  4.删除一个结点;

  下面通过例题来说明这些操作。

  [例7.10]建立一个三个结点的链表,存放学生数据。为简单起见,我们假定学生数据结构中只有学号和年龄两项。

  可编写一个建立链表的函数creat。程序如下:

  #define NULL 0

  #define TYPE struct stu

  #define LEN sizeof (struct stu)

  struct stu

  {

  int num;

  int age;

  struct stu *next;

  };

  TYPE *creat(int n)

  {

  struct stu *head,*pf,*pb;

  int i;

  for(i=0;i

  {

  pb=(TYPE*) malloc(LEN);

  printf("input Number and Agen");

  scanf("%d%d",&pb->num,&pb->age);

  if(i==0)

  pf=head=pb;

  else pf->next=pb;

  pb->next=NULL;

  pf=pb;

  }

  return(head);

  }

  在函数外首先用宏定义对三个符号常量作了定义。这里用TYPE表示struct stu,用LEN表示sizeof(struct stu)主要的目的是为了在以下程序内减少书写并使阅读更加方便。结构stu定义为外部类型,程序中的各个函数均可使用该定义。

  creat函数用于建立一个有n个结点的链表,它是一个指针函数,它返回的指针指向stu结构。在creat函数内定义了三个stu结构的指针变量。head为头指针,pf 为指向两相邻结点的前一结点的指针变量。pb为后一结点的指针变量。在for语句内,用malloc函数建立长度与stu长度相等的空间作为一结点,首地址赋予pb.然后输入结点数据。如果当前结点为第一结点(i==0),则把pb值 (该结点指针)赋予head和pf。如非第一结点,则把pb值赋予pf 所指结点的指针域成员next.而pb所指结点为当前的最后结点,其指针域赋NULL。再把pb值赋予pf以作下一次循环准备。

  creat函数的形参n,表示所建链表的结点数,作为for语句的循环次数。图7.4表示了creat函数的执行过程。

  [例7.11]写一个函数,在链表中按学号查找该结点。

  TYPE * search (TYPE *head,int n)

  {

  TYPE *p;

  int i;

  p=head;

  while (p->num!=n && p->next!=NULL)

  p=p->next; /* 不是要找的结点后移一步*/

  if (p->num==n) return (p);

  if (p->num!=n&& p->next==NULL)

  printf ("Node %d has not been found!n",n

  }

  本函数中使用的符号常量TYPE与例7.10的宏定义相同,等于struct stu.函数有两个形参,head是指向链表的指针变量,n为要查找的学号。进入while语句,逐个检查结点的num成员是否等于n,如果不等于n且指针域不等于NULL(不是最后结点)则后移一个结点,继续循环。如找到该结点则返回结点指针。如循环结束仍未找到该结点则输出"未找到"的提示信息。

  [例7.12]写一个函数,删除链表中的指定结点。删除一个结点有两种情况:

  1. 被删除结点是第一个结点。这种情况只需使head指向第二个结点即可。即head=pb->next。其过程如图7.5所示。

  2. 被删结点不是第一个结点,这种情况使被删结点的前一结点指向被删结点的后一结点即可。即pf->next=pb->next.

  函数编程如下:

  TYPE * delete(TYPE * head,int num)

  {

  TYPE *pf,*pb;

  if(head==NULL) /*如为空表, 输出提示信息*/

  {

  printf("nempty list!n");

  goto end;

  }

  pb=head;

  while (pb->num!=num && pb->next!=NULL)

  /*当不是要删除的结点,而且也不是最后一个结点时,继续循环*/

  {

  pf=pb;pb=pb->next;}/*pf指向当前结点,pb指向下一结点*/

  if(pb->num==num)

  {

  if(pb==head) head=pb->next;

  /*如找到被删结点,且为第一结点,则使head指向第二个结点,

  否则使pf所指结点的指针指向下一结点*/

  else pf->next=pb->next;

  free(pb);

  printf("The node is deletedn");}

  else

  printf("The node not been foud!n");

  end:

  return head;

  }

  函数有两个形参,head为指向链表第一结点的指针变量,num删结点的学号。 首先判断链表是否为空,为空则不可能有被删结点。若不为空,则使pb指针指向链表的第一个结点。进入while语句后逐个查找被删结点。找到被删结点之后再看是否为第一结点,若是则使head指向第二结点(即把第一结点从链中删去),否则使被删结点的前一结点(pf所指)指向被删结点的后一结点(被删结点的指针域所指)。如若循环结束未找到要删的结点, 则输出"末找到"的提示信息。最后返回head值。

  [例7.13]写一个函数,在链表中指定位置插入一个结点。在一个链表的指定位置插入结点, 要求链表本身必须是已按某种规律排好序的。例如,在学生数据链表中, 要求学号顺序插入一个结点。设被插结点的指针为pi. 可在三种不同情况下插入。

责编:罗莉

发表评论(共0条评论)
请自觉遵守互联网相关政策法规,评论内容只代表网友观点,发表审核后显示!

国家电网校园招聘考试直播课程通关班

  • 讲师:刘萍萍 / 谢楠
  • 课时:160h
  • 价格 4580

特色双名师解密新课程高频考点,送国家电网教材讲义,助力一次通关

配套通关班送国网在线题库一套

课程专业名称
讲师
课时
查看课程

国家电网招聘考试录播视频课程

  • 讲师:崔莹莹 / 刘萍萍
  • 课时:180h
  • 价格 3580

特色解密新课程高频考点,免费学习,助力一次通关

配套全套国网视频课程免费学习

课程专业名称
讲师
课时
查看课程
在线题库
面授课程更多>>
图书商城更多>>
在线报名
  • 报考专业:
    *(必填)
  • 姓名:
    *(必填)
  • 手机号码:
    *(必填)
返回顶部