版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 特种作业-高压电工试题及答案
- 电梯基础知识课件
- 设计公司品牌发展现状及未来趋势分析
- 百香果采收、分级包装技术规范-编制说明
- 动画运动规律课件
- 江苏省高层民用建筑工程消防验收现场评定指南(试行)
- 2024年硫代硫酸盐项目发展计划
- 山东省青岛市2021届高三地理下学期5月统一模拟检测二模试题
- 2024年电子产品制造设备:工装夹具项目建议书
- 小班绘本好饿的小蛇教案反思
- 历史人物大家说 校本课程实施方案
- (中职)人文艺术欣赏第一章-历史长河-中国悠久历史课件
- 小学综合实践一年级上册第2单元《主题活动一:背上背包去秋游》教案
- 建筑施工劳动力计划表格
- EPC地质灾害治理项目实施方案
- 三年级美术(上册)课件-《快乐的回忆》教学课件
- 六三制青岛版三年级科学上册第五单元《地球上的水》全部课件(一共4课时)
- 新生儿被盗应急演练脚本
- 流动儿童主动搜索表儿童流入流出登记
- 教学课件·有效沟通与实用写作教程
- 办公区域使用规范
评论
0/150
提交评论