C语言教程:第七章:结构与联合(4) 英语四级作文·大学英语作文·高考英语作文·高中英语作文·考研英语作文·英语六级作文
入党申请书·入党思想汇报·初中英语作文·中考英语作文·小学英语作文·英语作文指导
网站首页  |  公文写作  |  实用文档  |  思想政治  |  个人简历  |  英语作文  |  演讲稿 | 英语计算机试题
高考试题  |  中考试题  |  职场技巧  |  高中作文  |  初中作文  |  小学作文  |  公务员考试  |  网站地图
 您现在的位置是:首页 > 英语计算机试题 > 计算机等级考试模拟题 > 正文
C语言教程:第七章:结构与联合(4)
收集整理:贝奇范文网网站 如文章涉及版权问题,请与我们联系

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

本新闻共4页,当前在第1页  1  2  3  4  

C语言教程:第七章:结构与联合(4)

上一篇:C语言教程:第八章:枚举,位运算
 最 新 文 章
收藏本页 | 友情连接 | Copyright @ 贝奇范文网 All Rights Reserved.