版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、C + 链表使用完整代码/*/*练习使用链表:创建链表、遍历链表、查找节点、添加 节点、删除节点*/#include stdio.h#include string.h#include assert.h#include stdlib.h#include windows.h#define COUNT 3/ 定义一个节点结构 体struct NODEunsigned long uID;char strName16; / 用指针的话会出访问冲突异常NODE *next;/ 创建一个具有 n 个节点的链表, 从键盘输入数据将其初始 化,并返回链表的首节点指针 NODE *createNode(int n
2、)NODE *pHead, / 首节点指针*pRear, / 尾节点指针pNew; / 新节点指针int i;char *strName = new char16;for (i=0; i<n; i+).pNew = new NODE;do.printf( 请输入 ID 和名称: ); scanf(%d %s,&pNew->uID, strName);if (strlen(strName) > 16).printf( 输入名称长度超出范围,请重新输 入: );Sleep(1000); while(strlen(strName) > 16); strcpy(pNew
3、->strName, strName); if (0=i).pRear = pHead = pNew;else.pRear->next = pNew; pNew->next = NULL; pRear = pNew;delete strName; return pHead;/打印链表中所有节点的数据 void printNode(NODE *pHead) NODE *pTemp = pHead; assert(pTemp != NULL); while (pTemp != NULL) .printf(%d %s ,pTemp->uID, pTemp->strNam
4、e);pTemp = pTemp->next;/ 查询链表中具有指定 ID 的节点,并返回此节点指针NODE *searchNode(NODE *pHead, unsigned long uID) NODE *pDest = pHead; assert(pDest != NULL);while (pDest->next!=NULL && pDest->uID!=uID).pDest = pDest->next; if (pDest->uID = uID).return pDest; else.printf( 搜索失败,未找到找定 ID 的节点! )
5、; return NULL;/ 删除指定 ID 的节点NODE *deleteNode(NODE *pHead, unsigned long uID) NODE *pDest, / 要删除的节点*pBefore; / 前一个节点 pDest = pHead; assert(pDest != NULL); while (pDest->next!=NULL && pDest->uID!=uID).pBefore = pDest;pDest = pDest->next;if (pDest->uID = uID).if (pDest = pHead).pHead
6、 = pDest->next;else.pBefore->next = pDest->next;free(pDest);printf( 节点已被删除! );else.printf( 未找到指定节点,无法将其删除! ); return pHead;/ 在指定 ID 的节点后插入一个新的节点NODE *insertNode(NODE *pHead, unsigned long uID)NODE *pDest, *pNew; pDest = pHead; assert(pDest != NULL); while(pDest->next!=NULL &&pDes
7、t->uID!=uID).pDest = pDest->next;if(pDest->uID = uID).pNew = new NODE; printf( 请输入新节点的 ID 和名称: );scanf(%d %s,&pNew->uID,pNew->strName); pNew->next = pDest->next; pDest->next = pNew; printf( 节点插入完成! );else.printf( 未找到指定节点! );return pHead;void main()NODE *pHead, *pDest;int
8、nSelect;bool isExit = false;unsigned long uID;printf( 请根据提示输入数据初始化链表: ); pHead = createNode(COUNT);assert(pHead != NULL);printf( 链表创建成功!存储数据如下: ); printNode(pHead);while (!isExit).printf( );printf( 请选择要进行的操作: ); printf(1. 打印出链表所有节点数据: ); printf(2. 输入 ID 查询名称。 );printf(3. 删除指定 ID 的节点。 );printf(4. 在指定
9、 ID 的节点后插入一个新的节点 );printf(5. 退出。 );printf( );scanf(%d,&nSelect);switch(nSelect).case 1:printf( 链表所有节点数据如下: ); printNode(pHead);break;case 2:printf( 请输入要查询的节点的 ID: ); scanf(%d,&uID);pDest = searchNode(pHead, uID);if (pDest != NULL).printf( 已找到节点,名字为: %s,pDest->strName); break;case 3:printf( 请输入要删除的节点的 ID: ); scanf(%d,&uID);pHead = deleteNode(pHead, uID); break;case 4:printf( 请输入要删除的节点的 I
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 商业数据分析与报告编写规范
- 2026年即时零售 家政维修服务项目可行性研究报告
- 2026年宠物派对策划项目公司成立分析报告
- 2026年交通数据项目可行性研究报告
- 2026年二氧化碳增强地热系统项目可行性研究报告
- 2026年先进半导体Chiplet架构项目公司成立分析报告
- 2026年政策影响下数字货币交易服务合同协议
- 2025-2026学年人教版初中美术九年级下册教学计划及进度表
- 2026年营养师资格考试题目营养学基础理论
- 2026年音乐基础知识及音乐鉴赏能力试题库
- 七下语文《骆驼祥子》考点总结及练习题(附答案)
- 山东省济南市2025-2026年高三上第一次模拟考试历史+答案
- (二诊)绵阳市2023级高三第二次诊断考试语文试卷A卷+B卷(含答案)
- 初中九年级上一元二次方程计算练习题及答案详解B2
- 中国涉外律师人才研究报告2025
- 2026年生产管理岗入职性格测试题及答案
- 2026年bjt商务能力考试试题
- 老年住院患者非计划性拔管分析2026
- (2025)70周岁以上老年人换长久驾照三力测试题库(含参考答案)
- 2025年汽车驾驶员技师考试试题及答案含答案
- 观看煤矿警示教育片写心得体会
评论
0/150
提交评论