热门标签 | 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



推荐阅读
  • 深入理解 SQL 视图、存储过程与事务
    本文详细介绍了SQL中的视图、存储过程和事务的概念及应用。视图为用户提供了一种灵活的数据查询方式,存储过程则封装了复杂的SQL逻辑,而事务确保了数据库操作的完整性和一致性。 ... [详细]
  • 根据最新发布的《互联网人才趋势报告》,尽管大量IT从业者已转向Python开发,但随着人工智能和大数据领域的迅猛发展,仍存在巨大的人才缺口。本文将详细介绍如何使用Python编写一个简单的爬虫程序,并提供完整的代码示例。 ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • C++实现经典排序算法
    本文详细介绍了七种经典的排序算法及其性能分析。每种算法的平均、最坏和最好情况的时间复杂度、辅助空间需求以及稳定性都被列出,帮助读者全面了解这些排序方法的特点。 ... [详细]
  • CentOS7源码编译安装MySQL5.6
    2019独角兽企业重金招聘Python工程师标准一、先在cmake官网下个最新的cmake源码包cmake官网:https:www.cmake.org如此时最新 ... [详细]
  • 本文详细介绍了如何使用 Yii2 的 GridView 组件在列表页面实现数据的直接编辑功能。通过具体的代码示例和步骤,帮助开发者快速掌握这一实用技巧。 ... [详细]
  • 解决PHP与MySQL连接时出现500错误的方法
    本文详细探讨了当使用PHP连接MySQL数据库时遇到500内部服务器错误的多种解决方案,提供了详尽的操作步骤和专业建议。无论是初学者还是有经验的开发者,都能从中受益。 ... [详细]
  • 本文详细介绍了如何通过多种编程语言(如PHP、JSP)实现网站与MySQL数据库的连接,包括创建数据库、表的基本操作,以及数据的读取和写入方法。 ... [详细]
  • 本文探讨了 Objective-C 中的一些重要语法特性,包括 goto 语句、块(block)的使用、访问修饰符以及属性管理等。通过实例代码和详细解释,帮助开发者更好地理解和应用这些特性。 ... [详细]
  • 题目Link题目学习link1题目学习link2题目学习link3%%%受益匪浅!-----&# ... [详细]
  • 本实验主要探讨了二叉排序树(BST)的基本操作,包括创建、查找和删除节点。通过具体实例和代码实现,详细介绍了如何使用递归和非递归方法进行关键字查找,并展示了删除特定节点后的树结构变化。 ... [详细]
  • 高效解决应用崩溃问题!友盟新版错误分析工具全面升级
    友盟推出的最新版错误分析工具,专为移动开发者设计,提供强大的Crash收集与分析功能。该工具能够实时监控App运行状态,快速发现并修复错误,显著提升应用的稳定性和用户体验。 ... [详细]
  • 本文详细介绍了C语言中链表的两种动态创建方法——头插法和尾插法,包括具体的实现代码和运行示例。通过这些内容,读者可以更好地理解和掌握链表的基本操作。 ... [详细]
  • 本文详细探讨了VxWorks操作系统中双向链表和环形缓冲区的实现原理及使用方法,通过具体示例代码加深理解。 ... [详细]
  • 并发编程:深入理解设计原理与优化
    本文探讨了并发编程中的关键设计原则,特别是Java内存模型(JMM)的happens-before规则及其对多线程编程的影响。文章详细介绍了DCL双重检查锁定模式的问题及解决方案,并总结了不同处理器和内存模型之间的关系,旨在为程序员提供更深入的理解和最佳实践。 ... [详细]
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社区 版权所有