版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
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年中国电信招聘考试EPI数量关系与资料分析常用公式与速算方法归纳
- 2026年学业成绩家校沟通技巧竞赛题
- 2026年社区网格法网融合知识测试题
- 2026年全员职场礼仪与沟通协作能力题库
- 2026年环境监测站建设与运行安全规范试题集
- 5 大自然的语言 课件(共20张)统编版语文八年级下册
- 2026年公务员面试应急应变类题型实战模拟题库
- 2026年高校档案馆信息化管理岗应聘笔试指南及数字化
- 轮机英语词汇
- GB/T 45081-2024人工智能管理体系
- 创伤性脾破裂课件
- 劳保用品发放记录
- TCECS-绿色建材评价标准-辐射制冷材料
- 基于PLC的船舶主机燃油粘度控制系统设计
- (正式版)HGT 22820-2024 化工安全仪表系统工程设计规范
- 2019新人教版高中地理选择性必修二全册重点知识点归纳总结 (复习必背)
- NB-T 47013.15-2021 承压设备无损检测 第15部分:相控阵超声检测
- TNPM-全面规范化生产维护简述
- 全过程工程咨询服务方案
评论
0/150
提交评论