热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

本科课程数据结构与算法实验2——单链表与双向循环链表的插入删除操作(C++实现)

篇首语:本文由编程笔记#小编为大家整理,主要介绍了本科课程数据结构与算法实验2——单链表与双向循环链表的插入删除操作(C++实现)相关的知识,希望对你有一定的参考价值。

篇首语:本文由编程笔记#小编为大家整理,主要介绍了本科课程数据结构与算法实验2——单链表与双向循环链表的插入删除操作(C++实现)相关的知识,希望对你有一定的参考价值。




大家好,我是【1+1=王】, 热爱java的计算机(人工智能)渣硕研究生在读。
如果你也对java、人工智能等技术感兴趣,欢迎关注,抱团交流进大厂!!!
Good better best, never let it rest, until good is better, and better best.


近期会把自己本科阶段的一些课程设计、实验报告等分享出来,供大家参考,希望对大家有帮助。


博客更新至专栏【课程设计实验报告】:https://blog.csdn.net/weixin_43598687/category_11640051.html



一、 实验目的
  1. 掌握线性表的链表表示;
  2. 实现单链表的插入操作
  3. 实现单链表的删除操作
  4. 实现双向链表的插入操作
  5. 实现双向链表的删除操作

二、 实验内容

1. 实验任务

a. 完成单链表的建立、插入和删除
b. 完成双向链表的建立、插入和删除


2. 程序设计

1) 数据输入(输入哪些数据、个数、类型、来源、输入方式)
节点个数:count;
节点元素值:temp;
要插入节点的位置和数值:num1、Data;
要删除节点的位置:num2;
2) 数据存储(输入数据在内存中的存储)
动态分配内存(pNode pNew = (pNode)malloc(sizeof(Node));)
3) 数据处理(说明处理步骤。若不是非常简单,需要绘制流程图)




4) 数据输出(贴图:程序运行结果截图。图幅大小适当,不能太大)


三、 实验环境
  1. 操作系统:WINDOWS 10
  2. 开发工具:VC++ 2013
  3. 实验设备:PC

四、源代码

1. 单链表的插入删除操作


  • pNode CreatList(); //创建链表函数
  • void TravelseList(pNode); //遍历链表函数
  • bool Insert_Node(pNode, int, int); //插入节点
  • int Del_Node(pNode, int); //删除节点

#include<iostream>
using namespace std;
typedef struct node

int data;
struct node *pNext;
Node, *pNode;
pNode CreatList(); //创建链表函数
void TravelseList(pNode); //遍历链表函数
bool Insert_Node(pNode, int, int); //插入节点
int Del_Node(pNode, int); //删除节点
int main()

pNode pHead &#61; NULL; //struct Node *pHead&#61;NULL
int Data;
int num;
pHead &#61; CreatList();
TravelseList(pHead);
cout << "输入要插入的位置和数据&#xff1a;";
cin >> num >> Data;
Insert_Node(pHead, num, Data);
TravelseList(pHead);
cout << "输入要删除的位置&#xff1a;";
cin >> num;
Del_Node(pHead, num);
TravelseList(pHead);
system("pause");
return 0;

//创建链表
pNode CreatList()

int count; //节点个数
int temp; //临时存储用户输入的节点的数据
pNode pHead &#61; (pNode)malloc(sizeof(Node)); //不存放有效数据的头结点
pNode pTail &#61; pHead; //链表的最后一个节点
pTail->pNext &#61; NULL; //最后一个节点指针置为空
cout << "输入节点个数" << endl;
cin >> count;
for (int i &#61; 0; i < count; i&#43;&#43;)

cout << "输入第" << i &#43; 1 << "个节点的数值" << endl;
cin >> temp;
pNode pNew &#61; (pNode)malloc(sizeof(Node)); //给新节点分配空间
pNew->data &#61; temp;
pTail->pNext &#61; pNew;
pNew->pNext &#61; NULL;
pTail &#61; pNew;

return pHead;

void TravelseList(pNode pHead)

cout << "链表的数据如下&#xff1a;";
pNode p &#61; pHead->pNext;
while (p !&#61; NULL)

cout << p->data << " ";
p &#61; p->pNext;

cout << endl;
return;

//插入
bool Insert_Node(pNode pHead, int front, int Data)

int i &#61; 0;
pNode _node &#61; pHead;
pNode pSwap; //交换指针
if ((front < 1) && (_node !&#61; NULL))

return false;

while (i < front - 1)

_node &#61; _node->pNext;
&#43;&#43;i;

pNode pNew &#61; (pNode)malloc(sizeof(Node));
pNew->data &#61; Data;
pSwap &#61; _node->pNext;
pNew &#61; _node->pNext;
pSwap &#61; pNew->pNext;
return true;

//删除
int Del_Node(pNode pHead, int back)

int i &#61; 0;
int Data;
pNode _node &#61; pHead;
pNode pSwap;
if ((back < 1) && (NULL &#61;&#61; _node->pNext))

printf("删除失败&#xff01;\\n");
return 0;

while (i < back - 1)

_node &#61; _node->pNext;
&#43;&#43;i;

pSwap &#61; _node->pNext;
Data &#61; pSwap->data;
_node->pNext &#61; _node->pNext->pNext;
free(pSwap);
return Data;


2. 双向循环链表的插入删除操作

头文件

#ifndef _DOUBLELINKLIST_H_
#define _DOUBLELINKLIST_H_
//
// 在此处包含 C 标准库头文件
//
#include <stdio.h>
#include<malloc.h>
//
// 在此处包含其他头文件
//

//
// 在此处定义数据结构
//
typedef int ElemType; // 链表中元素的类型
typedef struct DuLNode
ElemType data; // 数据域
struct DuLNode* prior; // 前趋指针
struct DuLNode* next; // 后继指针
DuLinkList;
//
// 在此处声明函数
//
int InsertBefore(DuLinkList* pListHead, int i, ElemType Elem);
int Delete(DuLinkList* pListHead, int i, ElemType* pElem);
#endif /* _DOUBLELINKLIST_H_ */

cpp文件

#include "DoubleLinkList.h"
#include
using namespace std;
int main(int argc, char* argv[])

int i;
ElemType Elem;
DuLinkList* pListHead; // 双向循环链表的表头指针&#xff0c;指向表头节点
DuLinkList* pListNode; // 双向循环链表节点指针
//
// 初始化双向循环链表的表头节点
//
pListHead &#61; (DuLinkList*)malloc(sizeof(DuLinkList));
pListHead->prior &#61; pListHead;
pListHead->next &#61; pListHead;
//
// 初始化双向循环链表的节点
//
for (i &#61; 8; i>0; i--)

pListNode &#61; (DuLinkList*)malloc(sizeof(DuLinkList));
pListNode->data &#61; i;
pListNode->next &#61; pListHead->next;
pListNode->prior &#61; pListHead;
pListHead->next->prior &#61; pListNode;
pListHead->next &#61; pListNode;

//
// 在第 i 个节点之前插入一个节点
//
InsertBefore(pListHead, 3, 88);
InsertBefore(pListHead, 20, 15); // 插入位置非法。插入失败。
//
// 删除第 i 个节点
//
Delete(pListHead, 3, &Elem);
Delete(pListHead, 20, &Elem); // 删除位置非法。删除失败。
//
// 销毁双向循环链表
//
while (pListHead->next !&#61; pListHead)

pListNode &#61; pListHead->next;
pListHead->next &#61; pListNode->next;
pListNode->next->prior &#61; pListHead;
free(pListNode);

free(pListHead);
return 0;

/*
功能&#xff1a;
在第 i 个节点之前插入一个节点。
参数&#xff1a;
pListHead -- 双向循环链表的表头指针
i -- 插入节点的位置。从 1 开始计数。
Elem -- 插入节点的值。
返回值&#xff1a;
如果插入成功返回 1
如果插入失败返回 0
*/

int InsertBefore(DuLinkList* pListHead, int i, ElemType Elem)

DuLinkList* pListNode&#61;NULL; // 节点指针
//
// TODO: 在此添加代码
//
if (i <&#61; 0 && i > 8)
cout << "插入非法" << endl;
else

DuLinkList* s &#61; (DuLinkList*)malloc(sizeof(DuLNode));
s->data &#61; Elem;
s->prior &#61; pListNode->prior;
pListNode->prior->next &#61; s;
s->next &#61; pListNode;
pListNode->prior &#61; s;

return 0;

/*
功能&#xff1a;
删除第 i 个节点。
参数&#xff1a;
pListHead -- 双向循环链表的表头指针
i -- 删除节点的位置。从 1 开始计数。
pElem -- 返回被删除节点的值。
返回值&#xff1a;
如果删除成功返回 1
如果删除失败返回 0
*/

int Delete(DuLinkList* pListHead, int i, ElemType* pElem)

DuLinkList* pListNode; // 节点指针
//
// TODO: 在此添加代码
//
if (i <&#61; 0 && i > 8)
cout << "插入非法" << endl;
else

pElem &#61; pListNode->data;
pListNode->prior->next &#61; pListNode->next;
pListNode->next->prior &#61; pListNode->prior;
free(pListNode);

return 0;



博客更新至专栏【课程设计实验报告】&#xff1a;https://blog.csdn.net/weixin_43598687/category_11640051.html



推荐阅读
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • Vue 2 中解决页面刷新和按钮跳转导致导航栏样式失效的问题
    本文介绍了如何通过配置路由的 meta 字段,确保 Vue 2 项目中的导航栏在页面刷新或内部按钮跳转时,始终保持正确的 active 样式。具体实现方法包括设置路由的 meta 属性,并在 HTML 模板中动态绑定类名。 ... [详细]
  • QUIC协议:快速UDP互联网连接
    QUIC(Quick UDP Internet Connections)是谷歌开发的一种旨在提高网络性能和安全性的传输层协议。它基于UDP,并结合了TLS级别的安全性,提供了更高效、更可靠的互联网通信方式。 ... [详细]
  • 深入理解 Oracle 存储函数:计算员工年收入
    本文介绍如何使用 Oracle 存储函数查询特定员工的年收入。我们将详细解释存储函数的创建过程,并提供完整的代码示例。 ... [详细]
  • Java 中的 BigDecimal pow()方法,示例 ... [详细]
  • golang常用库:配置文件解析库/管理工具viper使用
    golang常用库:配置文件解析库管理工具-viper使用-一、viper简介viper配置管理解析库,是由大神SteveFrancia开发,他在google领导着golang的 ... [详细]
  • 使用Numpy实现无外部库依赖的双线性插值图像缩放
    本文介绍如何仅使用Numpy库,通过双线性插值方法实现图像的高效缩放,避免了对OpenCV等图像处理库的依赖。文中详细解释了算法原理,并提供了完整的代码示例。 ... [详细]
  • PyCharm下载与安装指南
    本文详细介绍如何从官方渠道下载并安装PyCharm集成开发环境(IDE),涵盖Windows、macOS和Linux系统,同时提供详细的安装步骤及配置建议。 ... [详细]
  • 本文总结了2018年的关键成就,包括职业变动、购车、考取驾照等重要事件,并分享了读书、工作、家庭和朋友方面的感悟。同时,展望2019年,制定了健康、软实力提升和技术学习的具体目标。 ... [详细]
  • 在计算机技术的学习道路上,51CTO学院以其专业性和专注度给我留下了深刻印象。从2012年接触计算机到2014年开始系统学习网络技术和安全领域,51CTO学院始终是我信赖的学习平台。 ... [详细]
  • 技术分享:从动态网站提取站点密钥的解决方案
    本文探讨了如何从动态网站中提取站点密钥,特别是针对验证码(reCAPTCHA)的处理方法。通过结合Selenium和requests库,提供了详细的代码示例和优化建议。 ... [详细]
  • CSS 布局:液态三栏混合宽度布局
    本文介绍了如何使用 CSS 实现液态的三栏布局,其中各栏具有不同的宽度设置。通过调整容器和内容区域的属性,可以实现灵活且响应式的网页设计。 ... [详细]
  • Linux 系统启动故障排除指南:MBR 和 GRUB 问题
    本文详细介绍了 Linux 系统启动过程中常见的 MBR 扇区和 GRUB 引导程序故障及其解决方案,涵盖从备份、模拟故障到恢复的具体步骤。 ... [详细]
  • 本文介绍了如何使用jQuery根据元素的类型(如复选框)和标签名(如段落)来获取DOM对象。这有助于更高效地操作网页中的特定元素。 ... [详细]
  • 本文介绍了Java并发库中的阻塞队列(BlockingQueue)及其典型应用场景。通过具体实例,展示了如何利用LinkedBlockingQueue实现线程间高效、安全的数据传递,并结合线程池和原子类优化性能。 ... [详细]
author-avatar
璨然2502869273
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有