• 网络学院
  • IT资讯
  • 操作系统
  • 网络技术
  • 软件应用
  • 办公软件
  • 编程技术
  • 网站架设
  • 数据库类
  • 平面设计
  • 多媒体类
  • 游戏资讯
  • 教学论文
  • 认证考试
C语言教程:第七章:结构与联合(4)
  站点:
  • 首 页
  • 最新软件
  • 文章教程
  • 国内软件
  • 国外软件
  • 绿色软件
  • 源码下载
  • 字体下载
C语言教程:第七章:结构与联合(4)
软件发布 C语言教程:第七章:结构与联合(4)
网络软件 系统工具 应用软件 联络聊天 图形图像 多媒体类 行业软件 游戏娱乐 编程开发 安全相关 教育教学 数码软件 绿软下载
热门软件: QQ 瑞星 pplive e话通 木马克星 千千静听 office2000 五笔字根 Photoshop 视频分割
返回文章教程首页 >> 认证考试 >> 计算机等级考试 >> 计算机等级考试动态 >> C语言教程:第七章:结构与联合(4)

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

添加时间: 2007-5-25 6:42:13  作者: 计算机等级考试认证参考  阅读次数:36   来源: http://www.d9soft.com

       

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

[例7.13]写一个函数,在链表中指定位置插入一个结点。在一个链表的指定位置插入结点, 要求链表本身必须是已按某种规律排好序的。例如,在学生数据链表中, 要求学号顺序插入一个结点。设被插结点的指针为pi。 可在三种不同情况下插入。   
1. 原表是空表,只需使head指向被插结点即可。见图7.7(a)

2. 被插结点值最小,应插入第一结点之前。这种情况下使head指向被插结点,被插结点的指针域指向原来的第一结点则可。即:pi->next=pb;   
head=pi; 见图7.7(b)   
3. 在其它位置插入,见图7.7(c)。这种情况下,使插入位置的前一结点的指针域指向被插结点,使被插结点的指针域指向插入位置的后一结点。即为:pi->next=pb;pf->next=pi;   
4. 在表末插入,见图7.7(d)。这种情况下使原表末结点指针域指向被插结点,被插结点指针域置为NULL。即:   
pb->next=pi;   
pi->next=NULL; TYPE * insert(TYPE * head,TYPE *pi)   
{   
TYPE *pf,*pb;   
pb=head;   
if(head==NULL) /*空表插入*/   
(head=pi;   
pi->next=NULL;}   
else   
{   
while((pi->num>pb->num)&&(pb->next!=NULL))   
{pf=pb;   
pb=pb->next; }/*找插入位置*/   
if(pi->num<=pb->num)   
{if(head==pb)head=pi;/*在第一结点之前插入*/   
else pf->next=pi;/*在其它位置插入*/   
pi->next=pb; }   
else   
{pb->next=pi;   
pi->next=NULL;} /*在表末插入*/   
}   
return head;}   
  本函数有两个形参均为指针变量,head指向链表,pi 指向被插结点。函数中首先判断链表是否为空,为空则使head指向被插结点。表若不空,则用while语句循环查找插入位置。找到之后再判断是否在第一结点之前插入,若是则使head 指向被插结点被插结点指针域指向原第一结点,否则在其它位置插入, 若插入的结点大于表中所有结点,则在表末插入。本函数返回一个指针,&nbsp;是链表的头指针。 当插入的位置在第一个结点之前时, 插入的新结点成为链表的第一个结点,因此head的值也有了改变, 故需要把这个指针返回主调函数。   
[例7.14]将以上建立链表,删除结点,插入结点的函数组织在一起,再建一个输出全部结点的函数,然后用main函数调用它们。   
#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 ");   
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 * delete(TYPE * head,int num)   
{   
TYPE *pf,*pb;   
if(head==NULL)   
{ printf(" empty list! ");   
goto end;}   
pb=head;   
while (pb->num!=num && pb->next!=NULL)

{pf=pb;pb=pb->next;}   
if(pb->num==num)   
{ if(pb==head) head=pb->next;   
else pf->next=pb->next;   
printf("The node is deleted "); }   
else   
free(pb);   
printf("The node not been found! ");   
end:   
return head;   
}   
TYPE * insert(TYPE * head,TYPE * pi)   
{   
TYPE *pb ,*pf;   
pb=head;   
if(head==NULL)   
{ head=pi;   
pi->next=NULL; }   
else   
{   
while((pi->num>pb-&gt;num)&&(pb->next!=NULL))   
{ pf=pb;   
pb=pb->next; }   
if(pi->num<=pb->num)   
{ if(head==pb) head=pi;   
else pf->next=pi;   
pi->next=pb; }   
else   
{ pb->next=pi;   
pi->next=NULL; }   
}   
return head;   
}   
void print(TYPE * head)   
{   
printf("Number Age ");   
while(head!=NULL)   
{   
printf("%d %d ",head->num,head->age);   
head=head->next;   
}   
}   
main()   
{   
TYPE * head,*pnum;   
int n,num;   
printf("input number of node: ");   
scanf("%d",&n);   
head=creat(n);   
print(head);   
printf("Input the deleted number: ");   
scanf("%d",&num);   
head=delete(head,num);   
print(head);   
printf("Input the inserted number and age: ");   
pnum=(TYPE *)malloc(LEN);   
scanf("%d%d",&pnum->num,&pnum->age);   
head=insert(head,pnum);   
print(head);   
}

 

上下文章:

 

上一篇文章: C语言教程:第六章:指针(1) 下一篇文章: 简明x86汇编语言教程(6)

相关文章:

  • 谷歌百科全书网站Knol推出多种语言服务
  • PS调色教程:教你调出婚片温柔暖色调
  • PS教程:打造都市颓废风格海报
  • PS教程:真人仿卡通手绘效果
  • 火星文:最时髦的网络语言

相关软件:

  • 易语言 V4.04 简体中文正式版
  • API拦截教程 V1.0
  • 脚本语言生成器 V2.5 Build 1050
  • 辰灿汇编语言集成开发环境 V1.0
  • 汇编语言学习工具 3.6
  • AI RoboForm Pass2Go(可携带版) 中文正式版/多国语言版 6.7.3

 

快速导航

  • 网络学院
  • 精品汇聚
  • 字体下载
  • 教程下载
  • ASP源码
  • PHP源码
  • Net源码
  • JSP 源码

计算机等级考试分类导航

  • 计算机等级考试动态
  • 计算机一级考试
  • 计算机二级考试
  • 计算机三级考试
  • 计算机四级考试

本类经典文章推荐

  • 全国计算机等级考试三级网络技术(...
  • 三级网络技术复习笔记(第1-2章)
  • 三级笔试样题(PC技术)
  • 三级数据库技术样题
  • 三级网络技术复习笔记(5-7)
  • 三级网络技术复习笔记(第3-4章)
  • 笔试样题(网络技术)
  • 机考如何避免范围性错误
  • 2003年最新三级网络模拟题(2)
  • 全国计算机等级考试三级网络技术部...

计算机等级考试动态阅读排行

  • 9月17日计算机等级考试二级VF答案
  • 完整的计算机等级考试上机模拟系统
  • 计算机等级考试:VFp练习题1
  • 全国计算机等级考试三级网络技术(...
  • 历年操作系统论述题及答案(2)
  • 计算机等级考试:VFp练习题2
  • 计算机二级VB软件环境、考试时间、...
  • 2005年全国计算机等级考试全真模拟...
  • 三级网络技术复习笔记(第1-2章)
  • 全国计算机等级考试报名时间、级别...

计算机等级考试阅读总排行

  • 全国计算机等级考试一级模拟试题01
  • 全国计算机等级考试一级模拟试题10
  • 全国计算机等级考试一级模拟试题08
  • 全国计算机等级考试一级考试最新模...
  • 全国计算机等级考试一级模拟试题02
  • 全国计算机等级考试一级模拟试题07
  • 全国计算机等级考试上机考试应试技...
  • 一级(WINDOWS)试题解析-Word篇
  • 全国计算机等级考试一级模拟试题06
  • 全国计算机等级考试一级模拟试题03

广告位置

字母检索 A B C D E F G H I J K L M N O P Q R S T U V W X Y Z 回到顶部

关于我们 | 版权声明 | 免责条款 | 广告联系 | 软件发布 | 下载帮助 | 下载排行 | 网站地图 | 特别鸣谢 | 友情连接

copyright; 2005-2008 D9soft.com 第九软件网 版权所有