清华严蔚敏《数据结构》的全部代码实现C语言

上传人:鲁** 文档编号:470081387 上传时间:2023-12-24 格式:DOC 页数:64 大小:205.50KB
返回 下载 相关 举报
清华严蔚敏《数据结构》的全部代码实现C语言_第1页
第1页 / 共64页
清华严蔚敏《数据结构》的全部代码实现C语言_第2页
第2页 / 共64页
清华严蔚敏《数据结构》的全部代码实现C语言_第3页
第3页 / 共64页
清华严蔚敏《数据结构》的全部代码实现C语言_第4页
第4页 / 共64页
清华严蔚敏《数据结构》的全部代码实现C语言_第5页
第5页 / 共64页
点击查看更多>>
资源描述

《清华严蔚敏《数据结构》的全部代码实现C语言》由会员分享,可在线阅读,更多相关《清华严蔚敏《数据结构》的全部代码实现C语言(64页珍藏版)》请在金锄头文库上搜索。

1、/* 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#defineINFEASIBLE -1/* #defin

2、e 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 /* 线性表存储空间的初始分配量 */#d

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

4、)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).listsize=0;return OK;

5、 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.length; Status GetElem(Sq

6、List 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满足关系compare()的数据元素的位序。

7、 */* 若这样的数据元素不存在,则返回值为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的数据元素,且不是第一个,则用pre_e返回它的前驱, */

8、* 否则操作失败,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.elem;while(iL.length&*

9、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(*L).length=(*L).lists

10、ize) /* 当前存储空间已满,增加分配 */ 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-1;p=q;-p) /* 插入位置及之后的元

11、素右移 */ *(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为被删除元素的位置 */ *e=*p; /*

12、被删除元素的值赋给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()改变元素的值 */ElemType *p;int i; p

13、=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_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

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 办公文档 > 解决方案

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号