




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 企业文化活动组织策划培训
- 探索电影中的教育意义
- 小淘气的安全教育
- 成本管理部工作总结
- 大学物理学 第一卷 经典物理基础 第6版 课件 11 光的偏振
- 施工合同的法律责任协议
- 商品质量测试协议(2篇)
- 《有意味的形》教学课件-2024-2025学年湘美版(2024)初中美术七年级下册
- 控烟教育主题班会
- 手工焊锡技能培训
- 2024年度网络安全技术知识产权保密协议合同3篇
- 急性早幼粒细胞白血病M3的护理
- 《《城市社会学-芝加哥学派城市研究文集》》
- DB11T 1200-2015 超长大体积混凝土结构跳仓法技术规程
- 【北京】八上地理知识点总结
- 燃料电池完整版本
- 人教鄂教版六年级下册科学全册知识点
- 2025届高考语文一轮复习:小说标题的含意及作用+课件
- 《数字经济概论:理论、实践与战略》札记
- 2024年贵州省黔西南州中考历史真题【附参考答案】
- DB11T 774-2010 新建物业项目交接查验标准
评论
0/150
提交评论