c链表使用完整代码_第1页
c链表使用完整代码_第2页
c链表使用完整代码_第3页
c链表使用完整代码_第4页
c链表使用完整代码_第5页
已阅读5页,还剩4页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论