- 1、本文档共6页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
数据结构 第1次上机作业 相关资料【HSH】2017-03-28 单链表, 补充
/*数据结构 第1次上机作业 【hsh, 2014-03-28】单链表, 补充 */
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
// 下面是一个单链表操作实例,供大家参考。
#includestring.h
#includectype.h
#includemalloc.h /* malloc()等 */
#includelimits.h /* INT_MAX等 */
#includestdio.h /* EOF(=^Z或F6),NULL */
#includestdlib.h /* atoi() */
#includeio.h /* eof() */
#includemath.h /* floor(),ceil(),abs() */
#includeprocess.h /* exit() */
/* 函数结果状态代码 */
#define TRUE 1
#define FALSE 0
#define OK 1
#define ERROR 0
#define INFEASIBLE -1
#define LIST_INIT_SIZE 100
#define LISTINCREMENT 10
/* #define OVERFLOW -2 因为在math.h中已定义OVERFLOW的值为3,故去掉此行 */
typedef int Status; /* Status是函数的类型,其值是函数结果状态代码,如OK等 */
typedef int Boolean; /* Boolean是布尔类型,其值是TRUE或FALSE */
typedef int ElemType;
/* c2-2.h 线性表的单链表存储结构 */
struct LNode
{
ElemType data;
struct LNode *next;
};
typedef struct LNode *LinkList; /* 另一种定义LinkList的方法 */
void visit(ElemType c) /* ListTraverse()调用的函数(类型要一致) */
{printf(%d ,c);}
Status equal(ElemType c1,ElemType c2)
{ /* 判断是否相等的函数,Union()用到 */
if(c1==c2)
return TRUE;
else
return FALSE;
}
//构造一个空表
Status InitList(LinkList *L)
{ /* 操作结果:构造一个空的线性表L */
*L=(LinkList)malloc(sizeof(struct LNode)); /* 产生头结点,并使L指向此头结点 */
if(!*L) /* 存储分配失败 */
exit(OVERFLOW);
(*L)-next=NULL; /* 指针域为空 */
return OK;
}
//求表长
int ListLength(LinkList L)
{ /* 初始条件:线性表L已存在。操作结果:返回L中数据元素个数 */
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(pji) /* 顺指针向后查找,直到p指向第i个元素或p为空 */
{p=p-next;
j++;}
if(!p||ji) /* 第i个元素不存在 */
return ERROR;
*e=p-data; /* 取第i个元素 */
return OK;
}
//用函数判断是表L否有满足关系的元素
int LocateElem(LinkList L,ElemType e,Status(*comp
您可能关注的文档
- 数技13-1申报材料 3.doc
- 数据中心简介.docx
- 数据库原理 第19~22讲 数据库保护(恢复、镜像).ppt
- 数据库原理15.ppt
- 数据库原理与应用:基于SQL+Server+2017课后答案.doc
- 数据库原理及应用-期末考试复习题及答案2017.doc
- 数据库原理及应用课件1.ppt
- 数据库原理实验指导书(2017-12-17).doc
- 数据库原理实验教案2017软件.doc
- 数据库原理期末考试习题1.doc
- 5.3.1函数的单调性(教学课件)--高中数学人教A版(2019)选择性必修第二册.pptx
- 部编版道德与法治2024三年级上册 《科技提升国力》PPT课件.pptx
- 2.7.2 抛物线的几何性质(教学课件)-高中数学人教B版(2019)选择性必修第一册.pptx
- 人教部编统编版小学六年级上册道德与法治9 知法守法 依法维权(第一课时)课件.pptx
- 三年级上册品德道德与法治《学习伴我成长》.pptx
- 部编版小学道德与法治六年级上册6 人大代表为人民 课件.pptx
- 部编版小学道德与法治六年级上册1感受生活中的法律第一课时课件.pptx
- 2.5.2圆与圆的位置关系(教学课件)-高中数学人教A版(2019)选择性必修第一册.pptx
- 2.5.1直线与圆的位置关系-(教学课件)--高中数学人教A版(2019)选择性必修第一册.pptx
- 14.1.1 同底数幂的乘法(教学课件)-初中数学人教版八年级上册.pptx
文档评论(0)