考试首页 | 考试用书 | 培训课程 | 模拟考场 | 考试论坛  
全国  |             |          |          |          |          |         
  当前位置:计算机等级 > 二级考试 > C语言程序设计 > C语言辅导 > 文章内容
  

全国计算机等级考试二级C语言入门教程(109)

中华IT学院   【 】  [ 2016年5月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 Age\n");
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。
其过程如图 7.6所示。
函数编程如下:
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 deleted\n");}
else
printf("The node not been foud!\n");
end:
return head;
}

首页 1 2 尾页
分享到:
本文纠错】【告诉好友】【打印此文】【返回顶部
将考试网添加到收藏夹 | 每次上网自动访问考试网 | 复制本页地址,传给QQ/MSN上的好友 | 申请链接 | 意见留言 TOP
关于本站  网站声明  广告服务  联系方式  站内导航  考试论坛
Copyright © 2006-2017 中华考试网(Examw.com) All Rights Reserved  营业执照