已阅读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年公开招聘专业化管理大学生村文书(补充)备考题库及答案详解1套
- 2025-2030淄博硼氢化钠行业市场现状供需平衡分析评估投资规划分析研究报告
- 2025-2030中国红外隐身粘合剂行业销售战略规划及投资效益分析研究报告
- 2025至2030中国再生塑料循环经济模式与政策支持研究报告
- 2025至2030中国污水处理膜技术应用场景拓展与运营效率提升分析报告
- 2025至2030中国儿童教育市场细分领域与增长动力研究报告
- 南京医科大学2026年招聘人事代理人员备考题库及一套答案详解
- T-CSUS 69-2024 智慧水务技术标准
- 国家开放大学法学本科《商法》历年期末考试试题及答案题库
- UL583标准中文版-2018电动工业车辆UL中文版标准
- 钢结构加工制造工艺
- 2024年新华东师大版七年级上册数学全册教案(新版教材)
- 新版高中物理必做实验目录及器材-(电子版)
- 冀人版五年级科学上册期末测试卷4份(含答案)
- 菜肴造型与盛装工艺
- 甲状腺癌医学知识讲座
- ABAQUS在隧道及地下工程中的应用
- 工作汇报PPT(山与海之歌动态)大气震撼模板
评论
0/150
提交评论