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



推荐阅读
  • 本文介绍了如何使用PHP向系统日历中添加事件的方法,通过使用PHP技术可以实现自动添加事件的功能,从而实现全局通知系统和迅速记录工具的自动化。同时还提到了系统exchange自带的日历具有同步感的特点,以及使用web技术实现自动添加事件的优势。 ... [详细]
  • 生成式对抗网络模型综述摘要生成式对抗网络模型(GAN)是基于深度学习的一种强大的生成模型,可以应用于计算机视觉、自然语言处理、半监督学习等重要领域。生成式对抗网络 ... [详细]
  • 《数据结构》学习笔记3——串匹配算法性能评估
    本文主要讨论串匹配算法的性能评估,包括模式匹配、字符种类数量、算法复杂度等内容。通过借助C++中的头文件和库,可以实现对串的匹配操作。其中蛮力算法的复杂度为O(m*n),通过随机取出长度为m的子串作为模式P,在文本T中进行匹配,统计平均复杂度。对于成功和失败的匹配分别进行测试,分析其平均复杂度。详情请参考相关学习资源。 ... [详细]
  • 本文由编程笔记#小编为大家整理,主要介绍了logistic回归(线性和非线性)相关的知识,包括线性logistic回归的代码和数据集的分布情况。希望对你有一定的参考价值。 ... [详细]
  • HDU 2372 El Dorado(DP)的最长上升子序列长度求解方法
    本文介绍了解决HDU 2372 El Dorado问题的一种动态规划方法,通过循环k的方式求解最长上升子序列的长度。具体实现过程包括初始化dp数组、读取数列、计算最长上升子序列长度等步骤。 ... [详细]
  • 本文讨论了在Windows 8上安装gvim中插件时出现的错误加载问题。作者将EasyMotion插件放在了正确的位置,但加载时却出现了错误。作者提供了下载链接和之前放置插件的位置,并列出了出现的错误信息。 ... [详细]
  • CSS3选择器的使用方法详解,提高Web开发效率和精准度
    本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
  • “你永远都不知道明天和‘公司的意外’哪个先来。”疫情期间,这是我们最战战兢兢的心情。但是显然,有些人体会不了。这份行业数据,让笔者“柠檬” ... [详细]
  • 本文介绍了OC学习笔记中的@property和@synthesize,包括属性的定义和合成的使用方法。通过示例代码详细讲解了@property和@synthesize的作用和用法。 ... [详细]
  • 本文主要解析了Open judge C16H问题中涉及到的Magical Balls的快速幂和逆元算法,并给出了问题的解析和解决方法。详细介绍了问题的背景和规则,并给出了相应的算法解析和实现步骤。通过本文的解析,读者可以更好地理解和解决Open judge C16H问题中的Magical Balls部分。 ... [详细]
  • 本文讨论了使用差分约束系统求解House Man跳跃问题的思路与方法。给定一组不同高度,要求从最低点跳跃到最高点,每次跳跃的距离不超过D,并且不能改变给定的顺序。通过建立差分约束系统,将问题转化为图的建立和查询距离的问题。文章详细介绍了建立约束条件的方法,并使用SPFA算法判环并输出结果。同时还讨论了建边方向和跳跃顺序的关系。 ... [详细]
  • 解决Cydia数据库错误:could not open file /var/lib/dpkg/status 的方法
    本文介绍了解决iOS系统中Cydia数据库错误的方法。通过使用苹果电脑上的Impactor工具和NewTerm软件,以及ifunbox工具和终端命令,可以解决该问题。具体步骤包括下载所需工具、连接手机到电脑、安装NewTerm、下载ifunbox并注册Dropbox账号、下载并解压lib.zip文件、将lib文件夹拖入Books文件夹中,并将lib文件夹拷贝到/var/目录下。以上方法适用于已经越狱且出现Cydia数据库错误的iPhone手机。 ... [详细]
  • sklearn数据集库中的常用数据集类型介绍
    本文介绍了sklearn数据集库中常用的数据集类型,包括玩具数据集和样本生成器。其中详细介绍了波士顿房价数据集,包含了波士顿506处房屋的13种不同特征以及房屋价格,适用于回归任务。 ... [详细]
  • 不同优化算法的比较分析及实验验证
    本文介绍了神经网络优化中常用的优化方法,包括学习率调整和梯度估计修正,并通过实验验证了不同优化算法的效果。实验结果表明,Adam算法在综合考虑学习率调整和梯度估计修正方面表现较好。该研究对于优化神经网络的训练过程具有指导意义。 ... [详细]
  • 动态规划算法的基本步骤及最长递增子序列问题详解
    本文详细介绍了动态规划算法的基本步骤,包括划分阶段、选择状态、决策和状态转移方程,并以最长递增子序列问题为例进行了详细解析。动态规划算法的有效性依赖于问题本身所具有的最优子结构性质和子问题重叠性质。通过将子问题的解保存在一个表中,在以后尽可能多地利用这些子问题的解,从而提高算法的效率。 ... [详细]
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社区 版权所有