清华严蔚敏数据结构资料的全部代码实现C语言_第1页
清华严蔚敏数据结构资料的全部代码实现C语言_第2页
清华严蔚敏数据结构资料的全部代码实现C语言_第3页
清华严蔚敏数据结构资料的全部代码实现C语言_第4页
清华严蔚敏数据结构资料的全部代码实现C语言_第5页
已阅读5页,还剩60页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、. .PAGE65 / NUMPAGES65/* c1.h (程序名) */#include#include#include /* malloc()等 */#include /* INT_MAX等 */#include /* EOF(=Z或F6),NULL */#include /* atoi() */#include /* eof() */#include /* floor(),ceil(),abs() */#include /* exit() */* 函数结果状态代码 */#defineTRUE 1#defineFALSE 0#defineOK 1#defineERROR 0#define

2、INFEASIBLE -1/* #define OVERFLOW -2 因为在math.h中已定义OVERFLOW的值为3,故去掉此行 */ typedef intStatus; /* Status是函数的类型,其值是函数结果状态代码,如OK等 */ typedef intBoolean; /* Boolean是布尔类型,其值是TRUE或FALSE */* algo2-1.c 实现算法2.1的程序 */#includec1.h typedef intElemType;#includec2-1.h/*c2-1.h 线性表的动态分配顺序存储结构 */#defineLIST_INIT_SIZE 10

3、 /* 线性表存储空间的初始分配量 */#defineLISTINCREMENT 2/* 线性表存储空间的分配增量 */typedefstruct ElemType*elem; /* 存储空间基址 */intlength; /* 当前长度 */intlistsize; /* 当前分配的存储容量(以sizeof(ElemType)为单位) */ SqList;#includebo2-1.c/* bo2-1.c 顺序表示的线性表(存储结构由c2-1.h定义)的基本操作(12个) */StatusInitList(SqList*L) /* 算法2.3 */ /* 操作结果:构造一个空的顺序线性表 *

4、/ (*L).elem=(ElemType*)malloc(LIST_INIT_SIZE*sizeof(ElemType);if(!(*L).elem)exit(OVERFLOW); /* 存储分配失败 */ (*L).length=0; /* 空表长度为0 */ (*L).listsize=LIST_INIT_SIZE; /* 初始存储容量 */return OK; StatusDestroyList(SqList*L) /* 初始条件:顺序线性表L已存在。操作结果:销毁顺序线性表L */ free(*L).elem); (*L).elem=NULL; (*L).length=0; (*L)

5、.listsize=0;return OK; StatusClearList(SqList*L) /* 初始条件:顺序线性表L已存在。操作结果:将L重置为空表 */ (*L).length=0;return OK; StatusListEmpty(SqList L) /* 初始条件:顺序线性表L已存在。操作结果:若L为空表,则返回TRUE,否则返回FALSE */if(L.length=0)return TRUE;elsereturn FALSE; int ListLength(SqList L) /* 初始条件:顺序线性表L已存在。操作结果:返回L中数据元素个数 */return L.len

6、gth; Status GetElem(SqList L,int i,ElemType *e) /* 初始条件:顺序线性表L已存在,1iListLength(L) */* 操作结果:用e返回L中第i个数据元素的值 */if(iL.length)exit(ERROR); *e=*(L.elem+i-1);return OK; int LocateElem(SqList L,ElemType e,Status(*compare)(ElemType,ElemType) /* 初始条件:顺序线性表L已存在,compare()是数据元素判定函数(满足为1,否则为0) */* 操作结果:返回L中第1个与e

7、满足关系compare()的数据元素的位序。 */* 若这样的数据元素不存在,则返回值为0。算法2.6 */ElemType *p;int i=1; /* i的初值为第1个元素的位序 */ p=L.elem; /* p的初值为第1个元素的存储位置 */while(i=L.length&!compare(*p+,e) +i;if(i=L.length)return i;elsereturn 0; Status PriorElem(SqList L,ElemType cur_e,ElemType *pre_e) /* 初始条件:顺序线性表L已存在 */* 操作结果:若cur_e是L的数据元素,且不

8、是第一个,则用pre_e返回它的前驱, */* 否则操作失败,pre_e无定义 */int i=2;ElemType *p=L.elem+1;while(iL.length)return INFEASIBLE;else *pre_e=*-p;return OK; Status NextElem(SqList L,ElemType cur_e,ElemType *next_e) /* 初始条件:顺序线性表L已存在 */* 操作结果:若cur_e是L的数据元素,且不是最后一个,则用next_e返回它的后继, */* 否则操作失败,next_e无定义 */int i=1;ElemType *p=L.

9、elem;while(iL.length&*p!=cur_e) i+; p+; if(i=L.length)return INFEASIBLE;else *next_e=*+p;return OK; Status ListInsert(SqList*L,int i,ElemType e) /* 算法2.4 */ /* 初始条件:顺序线性表L已存在,1iListLength(L)+1 */* 操作结果:在L中第i个位置之前插入新的数据元素e,L的长度加1 */ElemType *newbase,*q,*p;if(i(*L).length+1) /* i值不合法 */return ERROR;if

10、(*L).length=(*L).listsize) /* 当前存储空间已满,增加分配 */ newbase=(ElemType *)realloc(*L).elem,(*L).listsize+LISTINCREMENT)*sizeof(ElemType);if(!newbase)exit(OVERFLOW); /* 存储分配失败 */ (*L).elem=newbase; /* 新基址 */ (*L).listsize+=LISTINCREMENT; /* 增加存储容量 */ q=(*L).elem+i-1; /* q为插入位置 */for(p=(*L).elem+(*L).length-

11、1;p=q;-p) /* 插入位置与之后的元素右移 */ *(p+1)=*p; *q=e; /* 插入e */ +(*L).length; /* 表长增1 */return OK; Status ListDelete(SqList*L,int i,ElemType *e) /* 算法2.5 */ /* 初始条件:顺序线性表L已存在,1iListLength(L) */* 操作结果:删除L的第i个数据元素,并用e返回其值,L的长度减1 */ElemType *p,*q;if(i(*L).length) /* i值不合法 */return ERROR; p=(*L).elem+i-1; /* p为

12、被删除元素的位置 */ *e=*p; /* 被删除元素的值赋给e */ q=(*L).elem+(*L).length-1; /* 表尾元素的位置 */for(+p;p=q;+p) /* 被删除元素之后的元素左移 */ *(p-1)=*p; (*L).length-; /* 表长减1 */return OK; Status ListTraverse(SqList L,void(*vi)(ElemType*) /* 初始条件:顺序线性表L已存在 */* 操作结果:依次对L的每个数据元素调用函数vi()。一旦vi()失败,则操作失败 */* vi()的形参加&,表明可通过调用vi()改变元素的值

13、*/ElemType *p;int i; p=L.elem;for(i=1;i=L.length;i+) vi(p+); printf(n);return OK; Status equal(ElemType c1,ElemType c2) /* 判断是否相等的函数,Union()用到 */if(c1=c2)return TRUE;elsereturn FALSE; void Union(SqList*La,SqList Lb) /* 算法2.1 */ /* 将所有在线性表Lb中但不在La中的数据元素插入到La中 */ElemType e;int La_len,Lb_len;int i; La_

14、len=ListLength(*La); /* 求线性表的长度 */ Lb_len=ListLength(Lb);for(i=1;i=Lb_len;i+) GetElem(Lb,i,&e); /* 取Lb中第i个数据元素赋给e */if(!LocateElem(*La,e,equal) /* La中不存在和e一样的元素,则插入之 */ ListInsert(La,+La_len,e); void print(ElemType *c) printf(%d ,*c); void main() SqList La,Lb;Status i;int j; i=InitList(&La);if(i=1)

15、/* 创建空表La成功 */for(j=1;j=5;j+) /* 在表La中插入5个元素 */ i=ListInsert(&La,j,j); printf(La= ); /* 输出表La的容 */ ListTraverse(La,print);InitList(&Lb); /* 也可不判断是否创建成功 */for(j=1;j=5;j+) /* 在表Lb中插入5个元素 */ i=ListInsert(&Lb,j,2*j); printf(Lb= ); /* 输出表Lb的容 */ ListTraverse(Lb,print); Union(&La,Lb); printf(new La= ); /*

16、 输出新表La的容 */ ListTraverse(La,print);/* algo2-2.c 实现算法2.2的程序 */#includec1.h typedef intElemType;#includec2-1.h#includebo2-1.cvoid MergeList(SqList La,SqList Lb,SqList*Lc) /* 算法2.2 */ /* 已知线性表La和Lb中的数据元素按值非递减排列。 */* 归并La和Lb得到新的线性表Lc,Lc的数据元素也按值非递减排列 */int i=1,j=1,k=0;int La_len,Lb_len;ElemType ai,bj;In

17、itList(Lc); /* 创建空表Lc */ La_len=ListLength(La); Lb_len=ListLength(Lb);while(i=La_len&j=Lb_len) /* 表La和表Lb均非空 */ GetElem(La,i,&ai); GetElem(Lb,j,&bj);if(ai=bj) ListInsert(Lc,+k,ai); +i; else ListInsert(Lc,+k,bj); +j; while(i=La_len) /* 表La非空且表Lb空 */ GetElem(La,i+,&ai); ListInsert(Lc,+k,ai); while(j=L

18、b_len) /* 表Lb非空且表La空 */ GetElem(Lb,j+,&bj); ListInsert(Lc,+k,bj); void print(ElemType *c) printf(%d ,*c); void main() SqList La,Lb,Lc;int j,a4=3,5,8,11,b7=2,6,8,9,11,15,20;InitList(&La); /* 创建空表La */for(j=1;j=4;j+) /* 在表La中插入4个元素 */ ListInsert(&La,j,aj-1); printf(La= ); /* 输出表La的容 */ ListTraverse(La

19、,print);InitList(&Lb); /* 创建空表Lb */for(j=1;j=7;j+) /* 在表Lb中插入7个元素 */ ListInsert(&Lb,j,bj-1); printf(Lb= ); /* 输出表Lb的容 */ ListTraverse(Lb,print); MergeList(La,Lb,&Lc); printf(Lc= ); /* 输出表Lc的容 */ ListTraverse(Lc,print); /* algo2-3.c 实现算法2.7的程序 */#includec1.h typedef intElemType;#includec2-1.h#include

20、bo2-1.cvoid MergeList(SqList La,SqList Lb,SqList*Lc) /* 算法2.7 */ /* 已知顺序线性表La和Lb的元素按值非递减排列。 */* 归并La和Lb得到新的顺序线性表Lc,Lc的元素也按值非递减排列 */ElemType *pa,*pa_last,*pb,*pb_last,*pc; pa=La.elem; pb=Lb.elem; (*Lc).listsize=(*Lc).length=La.length+Lb.length;/*不用InitList()创建空表Lc */ pc=(*Lc).elem=(ElemType *)malloc(

21、*Lc).listsize*sizeof(ElemType);if(!(*Lc).elem) /* 存储分配失败 */exit(OVERFLOW); pa_last=La.elem+La.length-1; pb_last=Lb.elem+Lb.length-1;while(pa=pa_last&pb=pb_last) /* 表La和表Lb均非空 */ /* 归并 */if(*pa=*pb) *pc+=*pa+;else *pc+=*pb+; while(pa=pa_last) /* 表La非空且表Lb空 */ *pc+=*pa+; /* 插入La的剩余元素 */while(pb=pb_las

22、t) /* 表Lb非空且表La空 */ *pc+=*pb+; /* 插入Lb的剩余元素 */ void print(ElemType *c) printf(%d ,*c); void main() SqList La,Lb,Lc;int j;InitList(&La); /* 创建空表La */for(j=1;j=5;j+) /* 在表La中插入5个元素 */ ListInsert(&La,j,j); printf(La= ); /* 输出表La的容 */ ListTraverse(La,print);InitList(&Lb); /* 创建空表Lb */for(j=1;j=5;j+) /*

23、在表Lb中插入5个元素 */ ListInsert(&Lb,j,2*j); printf(Lb= ); /* 输出表Lb的容 */ ListTraverse(Lb,print); MergeList(La,Lb,&Lc); printf(Lc= ); /* 输出表Lc的容 */ ListTraverse(Lc,print); /* algo2-4.c 修改算法2.7的第一个循环语句中的条件语句为开关语句,且当 */* *pa=*pb时,只将两者中之一插入Lc。此操作的结果和算法2.1一样 */#includec1.h typedef intElemType;#includec2-1.h#inc

24、ludebo2-1.cint comp(ElemType c1,ElemType c2) int i;if(c1c2) i=1;elseif(c1=c2) i=0;else i=-1;return i; void MergeList(SqList La,SqList Lb,SqList*Lc) /* 另一种合并线性表的方法(根据算法2.7下的要求修改算法2.7) */ElemType *pa,*pa_last,*pb,*pb_last,*pc; pa=La.elem; pb=Lb.elem; (*Lc).listsize=La.length+Lb.length; /* 此句与算法2.7不同 *

25、/ pc=(*Lc).elem=(ElemType *)malloc(*Lc).listsize*sizeof(ElemType);if(!(*Lc).elem)exit(OVERFLOW); pa_last=La.elem+La.length-1; pb_last=Lb.elem+Lb.length-1;while(pa=pa_last&pb=pb_last) /* 表La和表Lb均非空 */ switch(comp(*pa,*pb) /* 此句与算法2.7不同 */ case 0: pb+; case 1: *pc+=*pa+; break; case -1: *pc+=*pb+; whi

26、le(pa=pa_last) /* 表La非空且表Lb空 */ *pc+=*pa+;while(pb=pb_last) /* 表Lb非空且表La空 */ *pc+=*pb+; (*Lc).length=pc-(*Lc).elem; /* 加此句 */ void print(ElemType *c) printf(%d ,*c); void main() SqList La,Lb,Lc;int j;InitList(&La); /* 创建空表La */for(j=1;j=5;j+) /* 在表La中插入5个元素 */ ListInsert(&La,j,j); printf(La= ); /* 输

27、出表La的容 */ ListTraverse(La,print);InitList(&Lb); /* 创建空表Lb */for(j=1;jnext=NULL; /* 指针域为空 */return OK; StatusDestroyList(LinkList *L) /* 初始条件:线性表L已存在。操作结果:销毁线性表L */ LinkList q;while(*L) q=(*L)-next; free(*L);*L=q; return OK; StatusClearList(LinkList L) /* 不改变L */ /* 初始条件:线性表L已存在。操作结果:将L重置为空表 */ LinkL

28、ist p,q; p=L-next; /* p指向第一个结点 */while(p) /* 没到表尾 */ q=p-next; free(p); p=q; L-next=NULL; /* 头结点指针域为空 */return OK; StatusListEmpty(LinkList L) /* 初始条件:线性表L已存在。操作结果:若L为空表,则返回TRUE,否则返回FALSE */if(L-next) /* 非空 */return FALSE;elsereturn TRUE; int ListLength(LinkList L) /* 初始条件:线性表L已存在。操作结果:返回L中数据元素个数 */

29、int i=0; LinkList p=L-next; /* p指向第一个结点 */while(p) /* 没到表尾 */ i+; p=p-next; return i; Status GetElem(LinkList L,int i,ElemType *e) /* 算法2.8 */ /* L为带头结点的单链表的头指针。当第i个元素存在时,其值赋给e并返回OK,否则返回ERROR */int j=1; /* j为计数器 */ LinkList p=L-next; /* p指向第一个结点 */while(p&jnext; j+; if(!p|ji) /* 第i个元素不存在 */return ER

30、ROR; *e=p-data; /* 取第i个元素 */return OK; int LocateElem(LinkList L,ElemType e,Status(*compare)(ElemType,ElemType) /* 初始条件: 线性表L已存在,compare()是数据元素判定函数(满足为1,否则为0) */* 操作结果: 返回L中第1个与e满足关系compare()的数据元素的位序。 */* 若这样的数据元素不存在,则返回值为0 */int i=0; LinkList p=L-next;while(p) i+;if(compare(p-data,e) /* 找到这样的数据元素 *

31、/return i; p=p-next; return 0; Status PriorElem(LinkList L,ElemType cur_e,ElemType *pre_e) /* 初始条件: 线性表L已存在 */* 操作结果: 若cur_e是L的数据元素,且不是第一个,则用pre_e返回它的前驱, */* 返回OK;否则操作失败,pre_e无定义,返回INFEASIBLE */ LinkList q,p=L-next; /* p指向第一个结点 */while(p-next) /* p所指结点有后继 */ q=p-next; /* q为p的后继 */if(q-data=cur_e) *p

32、re_e=p-data;return OK; p=q; /* p向后移 */ return INFEASIBLE; Status NextElem(LinkList L,ElemType cur_e,ElemType *next_e) /* 初始条件:线性表L已存在 */* 操作结果:若cur_e是L的数据元素,且不是最后一个,则用next_e返回它的后继, */* 返回OK;否则操作失败,next_e无定义,返回INFEASIBLE */ LinkList p=L-next; /* p指向第一个结点 */while(p-next) /* p所指结点有后继 */ if(p-data=cur_e

33、) *next_e=p-next-data;return OK; p=p-next; return INFEASIBLE; Status ListInsert(LinkList L,int i,ElemType e) /* 算法2.9。不改变L */ /* 在带头结点的单链线性表L中第i个位置之前插入元素e */int j=0; LinkList p=L,s;while(p&jnext; j+; if(!p|ji-1) /* i小于1或者大于表长 */return ERROR; s=(LinkList)malloc(sizeof(struct LNode); /* 生成新结点 */ s-dat

34、a=e; /* 插入L中 */ s-next=p-next; p-next=s;return OK; Status ListDelete(LinkList L,int i,ElemType *e) /* 算法2.10。不改变L */ /* 在带头结点的单链线性表L中,删除第i个元素,并由e返回其值 */int j=0; LinkList p=L,q;while(p-next&jnext; j+; if(!p-next|ji-1) /* 删除位置不合理 */return ERROR; q=p-next; /* 删除并释放结点 */ p-next=q-next; *e=q-data; free(q

35、);return OK; Status ListTraverse(LinkList L,void(*vi)(ElemType)/* vi的形参类型为ElemType,与bo2-1.c中相应函数的形参类型ElemType&不同 */ /* 初始条件:线性表L已存在 */* 操作结果:依次对L的每个数据元素调用函数vi()。一旦vi()失败,则操作失败 */ LinkList p=L-next;while(p) vi(p-data); p=p-next; printf(n);return OK; void CreateList(LinkList *L,int n) /* 算法2.11 */ /*

36、逆位序(插在表头)输入n个元素的值,建立带表头结构的单链线性表L */int i; LinkList p;*L=(LinkList)malloc(sizeof(struct LNode); (*L)-next=NULL; /* 先建立一个带头结点的单链表 */ printf(请输入%d个数据n,n);for(i=n;i0;-i) p=(LinkList)malloc(sizeof(struct LNode); /* 生成新结点 */ scanf(%d,&p-data); /* 输入元素值 */ p-next=(*L)-next; /* 插入到表头 */ (*L)-next=p; void Cr

37、eateList2(LinkList *L,int n) /* 正位序(插在表尾)输入n个元素的值,建立带表头结构的单链线性表 */int i; LinkList p,q;*L=(LinkList)malloc(sizeof(struct LNode); /* 生成头结点 */ (*L)-next=NULL; q=*L; printf(请输入%d个数据n,n);for(i=1;idata); q-next=p; q=q-next; p-next=NULL; void MergeList(LinkList La,LinkList *Lb,LinkList *Lc)/* 算法2.12 */ /*

38、已知单链线性表La和Lb的元素按值非递减排列。 */* 归并La和Lb得到新的单链线性表Lc,Lc的元素也按值非递减排列 */ LinkList pa=La-next,pb=(*Lb)-next,pc;*Lc=pc=La; /* 用La的头结点作为Lc的头结点 */while(pa&pb)if(pa-datadata) pc-next=pa; pc=pa; pa=pa-next; else pc-next=pb; pc=pb; pb=pb-next; pc-next=pa?pa:pb; /* 插入剩余段 */ free(*Lb); /* 释放Lb的头结点 */ Lb=NULL; void vi

39、sit(ElemType c) /* ListTraverse()调用的函数(类型要一致) */ printf(%d ,c); void main() int n=5; LinkList La,Lb,Lc; printf(按非递减顺序, ); CreateList2(&La,n); /* 正位序输入n个元素的值 */ printf(La=); /* 输出链表La的容 */ ListTraverse(La,visit); printf(按非递增顺序, ); CreateList(&Lb,n); /* 逆位序输入n个元素的值 */ printf(Lb=); /* 输出链表Lb的容 */ ListT

40、raverse(Lb,visit); MergeList(La,&Lb,&Lc); /* 按非递减顺序归并La和Lb,得到新表Lc */ printf(Lc=); /* 输出链表Lc的容 */ ListTraverse(Lc,visit); /* algo2-6.c 利用单链表结构处理教科书图2.1(学生健康登记表) */#includec1.h#define NAMELEN 8 /* 最大长度 */#define CLASSLEN 4 /* 班级名最大长度 */struct stud /* 记录的结构 */ char nameNAMELEN+1; long num; char sex;int

41、 age; char ClassCLASSLEN+1;int health; ;typedefstruct stud ElemType; /* 链表结点元素类型为结构体 */#includec2-2.h char sta39=健康 ,一般 ,神经衰弱; /* 健康状况(3类) */ FILE *fp;StatusInitList(LinkList *L) /* 拷自bo2-2.c */ /* 操作结果:构造一个空的线性表L */*L=(LinkList)malloc(sizeof(struct LNode); /* 产生头结点,并使L指向此头结点 */if(!*L) /* 存储分配失败 */e

42、xit(OVERFLOW); (*L)-next=NULL; /* 指针域为空 */return OK; Status ListTraverse(LinkList L,void(*vi)(ElemType) /* 拷自bo2-2.c */ /* 初始条件:线性表L已存在 */* 操作结果:依次对L的每个数据元素调用函数vi()。一旦vi()失败,则操作失败 */ LinkList p=L-next;while(p) vi(p-data); p=p-next; printf(n);return OK; void InsertAscend(LinkList L,ElemType e) /* 此函数

43、是由bo2-9.c中的同名函数改写 */ /* 按学号非降序插入 */ LinkList q=L,p=L-next;while(p&e.nump-data.num) q=p; p=p-next; q-next=(LinkList)malloc(sizeof(struct LNode); /* 插在q后 */ q-next-data=e; q-next-next=p; void Print(struct stud e) /* 显示记录e的容 */ printf(%-8s %6ld,,e.num);if(e.sex=m) printf( 男);else printf( 女); prin

44、tf(%5d %-4s,e.age,e.Class); printf(%9sn,stae.health); void ReadIn(struct stud *e) /* 由键盘输入结点信息 */ printf(请输入(name); printf(请输入学号: ); scanf(%ld,&e-num); printf(请输入性别(m:男 f:女): ); scanf(%*c%c,&e-sex); printf(请输入年龄: ); scanf(%d,&e-age); printf(请输入班级(Class); printf(请输入健康状况(0:%s 1:%s 2:%s):,sta0,sta1,sta

45、2); scanf(%d,&e-health); void WriteToFile(struct stud e) /* 将结点信息写入fp指定的文件 */ fwrite(&e,sizeof(struct stud),1,fp); Status ReadFromFile(struct stud *e) /* 由fp指定的文件读取结点信息到e */int i; i=fread(e,sizeof(struct stud),1,fp);if(i=1) /* 读取文件成功 */return OK;elsereturn ERROR; Status FindFromNum(LinkList L,long n

46、um,LinkList *p,LinkList *q) /* 查找表中学号为num的结点,如找到,q指向此结点,p指向q的前驱, */* 并返回TRUE;如无此元素,则返回FALSE */ *p=L;while(*p) *q=(*p)-next;if(*q&(*q)-data.numnum) /* 因为是按学号非降序排列 */ break;if(*q&(*q)-data.num=num) /* 找到该学号 */return TRUE; *p=*q; return FALSE; Status FindFromName(LinkList L,char name,LinkList *p,LinkLi

47、st *q) /* 查找表中为name的结点,如找到,q指向此结点,p指向q的前驱, */* 并返回TRUE;如无此元素,则返回FALSE */ *p=L;while(*p) *q=(*p)-next;if(*q&!strcmp(*q)-,name) /* 找到该 */return TRUE; *p=*q; return FALSE; Status DeleteElemNum(LinkList L,long num) /* 删除表中学号为num的元素,并返回TRUE;如无此元素,则返回FALSE */ LinkList p,q;if(FindFromNum(L,num,&p,

48、&q) /* 找到此结点,且q指向其,p指向其前驱 */ p-next=q-next; free(q);return TRUE; return FALSE; Status DeleteElemName(LinkList L,char name) /* 删除表中为name的元素,并返回TRUE;如无此元素,则返回FALSE */ LinkList p,q;if(FindFromName(L,name,&p,&q) /* 找到此结点,且q指向其,p指向其前驱 */ p-next=q-next; free(q);return TRUE; return FALSE; void Modify(ElemT

49、ype *e) /* 修改结点容 */ char s80; Print(*e); /* 显示原容 */ printf(请输入待修改项的容,不修改的项按回车键保持原值:n); printf(请输入(name,s); printf(请输入学号: ); gets(s);if(strlen(s) e-num=atol(s); printf(请输入性别(m:男 f:女): ); gets(s);if(strlen(s) e-sex=s0; printf(请输入年龄: ); gets(s);if(strlen(s) e-age=atoi(s); printf(请输入班级(Class,s); printf(

50、请输入健康状况(0:%s 1:%s 2:%s):,sta0,sta1,sta2); gets(s);if(strlen(s) e-health=atoi(s); /* 修改完毕 */ #define N 4 /* student记录的个数 */void main() struct stud studentN=王小林,790631,m,18,计91,0, 红,790632,f,20,计91,1, 建平,790633,m,21,计91,0, 立立,790634,m,17,计91,2; /* 表的初始记录 */int i,j,flag=1; long num; char filename13,nam

51、eNAMELEN+1;ElemType e; LinkList T,p,q;InitList(&T); /* 初始化链表 */while(flag) printf(1:将结构体数组student中的记录按学号非降序插入链表n); printf(2:将文件中的记录按学号非降序插入链表n); printf(3:键盘输入新记录,并将其按学号非降序插入链表n); printf(4:删除链表中第一个有给定学号的记录n); printf(5:删除链表中第一个有给定的记录n); printf(6:修改链表中第一个有给定学号的记录n); printf(7:修改链表中第一个有给定的记录n); printf(8:

52、查找链表中第一个有给定学号的记录n); printf(9:查找链表中第一个有给定的记录n); printf(10:显示所有记录 11:将链表中的所有记录存入文件 12:结束n); printf(请选择操作命令: ); scanf(%d,&i); switch(i) case 1: for(j=0;jdata);if(q-data.num!=num) /* 学号被修改 */ p-next=q-next; /* 把q所指的结点从L中删除 */ InsertAscend(T,q-data); /* 把元素插入L */ free(q); /* 删除q */ break; case 7: printf(

53、请输入待修改记录的: ); scanf(%s%*c,name); /* %*c吃掉回车符 */if(!FindFromName(T,name,&p,&q) printf(没有为%s的记录n,name);else num=q-data.num; /* 学号存入num */ Modify(&q-data);if(q-data.num!=num) /* 学号被修改 */ p-next=q-next; /* 把q所指的结点从L中删除 */ InsertAscend(T,q-data); /* 把元素插入L */ free(q); /* 删除q */ break; case 8: printf(请输入待

54、查找记录的学号: ); scanf(%ld,&num);if(!FindFromNum(T,num,&p,&q) printf(没有学号为%ld的记录n,num);else Print(q-data); break; case 9: printf(请输入待查找记录的: ); scanf(%s,name);if(!FindFromName(T,name,&p,&q) printf(没有为%s的记录n,name);else Print(q-data); break; case 10:printf( 学号 性别 年龄 班级 健康状况n); ListTraverse(T,Print); break;

55、case 11:printf(请输入文件名: ); scanf(%s,filename);if(fp=fopen(filename,wb)=NULL) printf(打开文件失败!n);else ListTraverse(T,WriteToFile); fclose(fp); break; case 12:flag=0; /* algo2-7.c 教科书中图2.10 静态链表示例 */* 第一个结点的位置在0.cur中,成员cur的值为0,则到链表尾 */#includec1.h#define N 6 /* 字符串长度 */typedef char ElemTypeN;#includec2-3

56、.h/* c2-3.h 线性表的静态单链表存储结构 */#define MAXSIZE 100 /* 链表的最大长度 */typedefstruct ElemType data;int cur; component,SLinkListMAXSIZE;void main() SLinkList s=,1,ZHAO,2,QIAN,3,SUN,4,LI,5,ZHOU,6,WU,7,ZHENG,8,WANG,0;int i; i=s0.cur;while(i) /* 输出教科书中图2.10(a)的状态 */ printf(%s ,si.data); /* 输出链表的当前值 */ i=si.cur; /

57、* 找到下一个 */ printf(n); s4.cur=9; /* 按教科书中图2.10(b)修改 */ s6.cur=8; s9.cur=5; strcpy(s9.data,SHI); i=s0.cur;while(i) /* 输出教科书中图2.10(b)的状态 */ printf(%s ,si.data); /* 输出链表的当前值 */ i=si.cur; /* 找到下一个 */ printf(n); /* algo2-8.c 实现算法2.17的程序 */#includec1.h#define N 2typedef char ElemType;#includec2-3.h#include

58、bo2-3.c/* bo2-3.c 实现算法2.15、2.16的程序 (数据结构由c2-3.h定义) (3个) */int Malloc(SLinkList space) /* 算法2.15 */ /* 若备用链表非空,则返回分配的结点下标(备用链表的第一个结点),否则返回0 */int i=space0.cur;if(i) /* 备用链表非空 */ space0.cur=spacei.cur; /* 备用链表的头结点指向原备用链表的第二个结点 */return i; /* 返回新开辟结点的坐标 */ void Free(SLinkList space,int k) /* 算法2.16 */

59、/* 将下标为k的空闲结点回收到备用链表(成为备用链表的第一个结点) */ spacek.cur=space0.cur; /* 回收结点的游标指向备用链表的第一个结点 */ space0.cur=k; /* 备用链表的头结点指向新回收的结点 */ void DestroyList() /* 静态数组不能被销毁 */ #includebo2-32.c/* bo2-32.c 一个数组可生成若干静态链表(数据结构由c2-3.h定义)的基本操作(12个) */void InitSpace(SLinkList L) /* 算法2.14。另加 */ /* 将一维数组L中各分量链成一个备用链表,L0.cur

60、为头指针。“0”表示空指针 */int i;for(i=0;iMAXSIZE-1;i+) Li.cur=i+1; LMAXSIZE-1.cur=0; intInitList(SLinkList L) /* 构造一个空链表,返回值为空表在数组中的位序 */int i; i=Malloc(L); /* 调用Malloc(),简化程序 */ Li.cur=0; /* 空链表的表头指针为空(0) */return i; StatusClearList(SLinkList L,int n) /* 初始条件:L中表头位序为n的静态链表已存在。操作结果:将此表重置为空表 */int j,k,i=Ln.cur

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论