3、数据结构笔记之三线性表代码实现_第1页
3、数据结构笔记之三线性表代码实现_第2页
3、数据结构笔记之三线性表代码实现_第3页
3、数据结构笔记之三线性表代码实现_第4页
3、数据结构笔记之三线性表代码实现_第5页
已阅读5页,还剩4页未读 继续免费阅读

下载本文档

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

文档简介

3、蛤蟆的数据结构笔记之三线性表单项链表实现今天励志短语“人生的价值,即以其人对于当代所做的工作为尺度。”昨天我们看了线性表的一些定义概念,今天来看下其中的单项链表代码如何实现。1声明结构如下声明一个指向结构的指针。存放整数的节点,我们也可以根据需要创建字符的链表TYPEDEFSTRUCTLIST_NODELIST_POINTERTYPEDEFSTRUCTLIST_NODEINTDATALIST_POINTERLINKLIST_POINTERPTRNULL2定义宏定义一个宏,来检测空表DEFINEIS_EMPTYPTRPTR定义宏,检查是否有可用空间。DEFINEIS_FULLPTRPTR3创建二节点的函数函数如下,创建两个节点FIRST和SECONDFIRST指向第一个节点,SECOND指向第二个节点。同时第一个节点中的LINK指向第二个节点。而第二个节点的LINK为NULL。LIST_POINTERCREATE2LIST_POINTERFIRST,SECONDFIRSTLIST_POINTERMALLOCSIZEOFLIST_NODESECONDLIST_POINTERMALLOCSIZEOFLIST_NODESECONDLINKNULLSECONDDATA2FIRSTDATA1FIRSTLINKSECONDRETURNFIRST4表的前端插入在表中前端插入一个值为DAT的节点,实现如下。考虑了首节点是否为空的情况。VOIDINSERTLIST_POINTERPTR,INTDATLIST_POINTERTEMPTEMPLIST_POINTERMALLOCSIZEOFLIST_NODEIFIS_FULLTEMPFPRINTFSTDERR,“THEMEMORYISFULLN“EXIT1TEMPDATADATIFPTRTEMPLINKPTRPTRTEMPELSETEMPLINKNULLPTRTEMP5节点的删除删除节点需要3个输入,一个是链表的起始,一个是删除点的前驱节点,另一个是删除的节点本身。要判断链表是否为空,为空就不能再FREE了。如果删除的是首节点,那么首节点的前驱节点一定是NULL,那么直接将TRAIL指向下一个即可。VOIDDELETENODELIST_POINTERPTR,LIST_POINTERTRAIL,LIST_POINTERNODEIFIS_EMPTYPTRFPRINTFSTDERR,“EMPTYLIST“EXIT1IFTRAILTRAILLINKNODELINKELSEPTRPTRLINKFREENODE6表的输出查看链表上有多少节点,输出节点中的数字。VOIDPRINT_LISTLIST_POINTERPTRPRINTF“THELISTCONTAINS“FORPTRPTRPTRLINKPRINTF“4D“,PTRDATAPRINTF“N“7表的释放我们必须保持释放的习惯。不然会吃亏的。VOIDFREE_LISTLIST_POINTERPTRLIST_POINTERTEMPNULLFORPTRTEMPPTRPTRPTRLINKTEMPLINKNULLFREETEMP8综合执行如下代码后VOIDMAINPTRCREATE2PRINT_LISTPTRPRINTF“AFTERINSERTN“INSERTPRINT_LISTPTRFREE_LISTPTR如下图1删除头结点,代码如下,如下图2PTRCREATE2PRINT_LISTPTRPRINTF“AFTERINSERTN“INSERTPRINT_LISTPTRDELETENODEPRINTF“AFTERDELETEFIRSTNODEN“PRINT_LISTPTRFREE_LISTPTR删除非头结点,代码/删除非头结点PTRCREATE2PRINT_LISTPTRPRINTF“AFTERINSERTN“INSERTPRINT_LISTPTRDELETENODEPRINTF“AFTERDELETENOFIRSTNODEN“PRINT_LISTPTRFREE_LISTPTR得到如下图39全部源码为方便大家调试,这里附上全部代码,可直接编译运行。蛤蟆在VS2012和LINUXGCC447编译均可正常运行INCLUDE“STDIOH“INCLUDE“STDLIBH“DEFINEIS_EMPTYPTRPTRDEFINEIS_FULLPTRPTRTYPEDEFSTRUCTLIST_NODELIST_POINTERTYPEDEFSTRUCTLIST_NODEINTDATALIST_POINTERLINKLIST_NODE/建立空表PTRLIST_POINTERPTRNULLVOIDINSERTLIST_POINTERPTR,INTDATLIST_POINTERTEMPTEMPLIST_POINTERMALLOCSIZEOFLIST_NODEIFIS_FULLTEMPFPRINTFSTDERR,“THEMEMORYISFULLN“EXIT1TEMPDATADATIFPTRTEMPLINKPTRPTRTEMPELSETEMPLINKNULLPTRTEMPVOIDDELETENODELIST_POINTERPTR,LIST_POINTERTRAIL,LIST_POINTERNODEIFIS_EMPTYPTRFPRINTFSTDERR,“EMPTYLIST“EXIT1IFTRAILTRAILLINKNODELINKELSEPTRPTRLINKFREENODEVOIDPRINT_LISTLIST_POINTERPTRPRINTF“THELISTCONTAINS“FORPTRPTRPTRLINKPRINTF“4D“,PTRDATAPRINTF“N“VOIDFREE_LISTLIST_POINTERPTRLIST_POINTERTEMPNULLFORPTRTEMPPTRPTRPTRLINKTEMPLINKNULLFREETEMPLIST_POINTERCREATE2LIST_POINTERFIRST,SECONDFIRSTLIST_POINTERMALLOCSIZEOFLIST_NODESECONDLIST_POINTERMALLOCSIZEOFLIST_NODESECONDLINKNULLSECONDDATA2FIRSTDATA1FIRSTLINKSECONDRETURNFIRSTVOIDMAIN/基本运行/PTRCREATE2PRINT_LISTPTRPRINTF“AFTERINSERTN“INSERTPRINT_LISTPTRFREE_LISTPTR/删除头结点PTRCREATE2PRINT_LISTPTRPRINTF“AFTERINSERTN“INSERTPRINT_LISTPTRDELETENODEPRINTF“AFTERDELETEFIRSTNODEN“PRINT_LISTPT

温馨提示

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

评论

0/150

提交评论