




已阅读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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 农业银行2025娄底市秋招半结构化面试题库及参考答案
- 交通银行2025百色市秋招笔试创新题型专练及答案
- 交通银行2025遂宁市信息科技岗笔试题及答案
- 农业银行2025克拉玛依市数据分析师笔试题及答案
- 建设银行2025佛山市秋招笔试EPI能力测试题专练及答案
- 工商银行2025天津市金融科技岗笔试题及答案
- 邮储银行2025淮南市秋招群面案例总结模板
- 工商银行2025邵阳市秋招英文面试题库及高分回答
- 建设银行2025丽水市秋招半结构化面试题库及参考答案
- 邮储银行2025铁岭市小语种岗笔试题及答案
- 计算流体力学完整课件
- 四大时态综合课件
- 拜耳法氧化铝生产工艺流程框图
- 行政主管岗位职责及工作内容
- 机关档案管理工作培训课件
- 八年级上教案全等三角形辅助线作法
- 碧桂园山营销示范区区抢工宝典课件
- 上海市环卫作业养护预算定额经费
- 钎焊工艺有关标准
- 高校电子课件:金融风险管理(第五版)
- 会议组织与服务完整版教学课件全书电子讲义(最新)
评论
0/150
提交评论