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



推荐阅读
  • UNP 第9章:主机名与地址转换
    本章探讨了用于在主机名和数值地址之间进行转换的函数,如gethostbyname和gethostbyaddr。此外,还介绍了getservbyname和getservbyport函数,用于在服务器名和端口号之间进行转换。 ... [详细]
  • 火星商店问题:线段树分治与持久化Trie树的应用
    本题涉及编号为1至n的火星商店,每个商店有一个永久商品价值v。操作包括每天在指定商店增加一个新商品,以及查询某段时间内某些商店中所有商品(含永久商品)与给定密码值的最大异或结果。通过线段树分治和持久化Trie树来高效解决此问题。 ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • 题目描述:给定n个半开区间[a, b),要求使用两个互不重叠的记录器,求最多可以记录多少个区间。解决方案采用贪心算法,通过排序和遍历实现最优解。 ... [详细]
  • CentOS7源码编译安装MySQL5.6
    2019独角兽企业重金招聘Python工程师标准一、先在cmake官网下个最新的cmake源码包cmake官网:https:www.cmake.org如此时最新 ... [详细]
  • 扫描线三巨头 hdu1928hdu 1255  hdu 1542 [POJ 1151]
    学习链接:http:blog.csdn.netlwt36articledetails48908031学习扫描线主要学习的是一种扫描的思想,后期可以求解很 ... [详细]
  • Splay Tree 区间操作优化
    本文详细介绍了使用Splay Tree进行区间操作的实现方法,包括插入、删除、修改、翻转和求和等操作。通过这些操作,可以高效地处理动态序列问题,并且代码实现具有一定的挑战性,有助于编程能力的提升。 ... [详细]
  • 题目Link题目学习link1题目学习link2题目学习link3%%%受益匪浅!-----&# ... [详细]
  • 本实验主要探讨了二叉排序树(BST)的基本操作,包括创建、查找和删除节点。通过具体实例和代码实现,详细介绍了如何使用递归和非递归方法进行关键字查找,并展示了删除特定节点后的树结构变化。 ... [详细]
  • 文件描述符、文件句柄与打开文件之间的关联解析
    本文详细探讨了文件描述符、文件句柄和打开文件之间的关系,通过具体示例解释了它们在操作系统中的作用及其相互影响。 ... [详细]
  • 本文详细介绍了C语言中链表的两种动态创建方法——头插法和尾插法,包括具体的实现代码和运行示例。通过这些内容,读者可以更好地理解和掌握链表的基本操作。 ... [详细]
  • 本文详细探讨了VxWorks操作系统中双向链表和环形缓冲区的实现原理及使用方法,通过具体示例代码加深理解。 ... [详细]
  • 本文深入探讨 MyBatis 中动态 SQL 的使用方法,包括 if/where、trim 自定义字符串截取规则、choose 分支选择、封装查询和修改条件的 where/set 标签、批量处理的 foreach 标签以及内置参数和 bind 的用法。 ... [详细]
  • 本文探讨了如何在模运算下高效计算组合数C(n, m),并详细介绍了乘法逆元的应用。通过扩展欧几里得算法求解乘法逆元,从而实现除法取余的计算。 ... [详细]
  • 本文探讨了如何在给定整数N的情况下,找到两个不同的整数a和b,使得它们的和最大,并且满足特定的数学条件。 ... [详细]
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社区 版权所有