数据结构(C语言版)代码实现(三)——单链表部分代码实现

目录

格式

头文件

宏定义

线性表的单链表存储结构

按位查找

插入元素

删除元素

头插法建立单链表

合并非递减单链表

其他基本操作

完整版

测试代码(主函数)

测试结果


格式

参考 2.3节 线性表的链式表示和实现

头文件

宏定义

#pragma once
#include <cstdio>
#include <cstdlib>
#include <cstring>#define TRUE 1
#define FALSE 0
#define OK 1
#define ERROR 0
#define INFEASIBLE -1
#define OVERFLOW -2
typedef int Status;//Status是函数的类型,其值是函数结果状态代码
typedef int ElemType;

线性表的单链表存储结构

//-----线性表的单链表存储结构-----
typedef struct LNode {ElemType data;struct LNode* next;
}LNode,*LinkList;

按位查找

//算法2.8 函数GetElem在单链表中的实现。
Status GetElem_L(LinkList L, int i, ElemType& e) {//L为带头结点的单链表的头指针。//当第i个元素存在时,其值赋给e并返回OK,否则返回ERRORLinkList p = L->next;int j = 1;//初始化,p指向第一个结点,j为计数器while (p && j < i) {//顺指针向后查找,直到p指向第i个元素或p为空p = p->next;++j;}if (!p || j > i)return ERROR;//第i个元素不存在e = p->data;//取第i个元素return OK;
}

插入元素

//算法2.9 函数ListInsert在单链表中的实现
Status ListInsert_L(LinkList& L, int i, ElemType e) {//在带头结点的单链线性表L中第i个位置之前插入元素eLinkList p = L;int j = 0;while (p && j < i - 1) {p = p->next;++j;//寻找第i-1个结点}if (!p || j > i - 1)return ERROR;//i小于1或者大于表长+1LinkList s = (LinkList)malloc(sizeof(LNode));//生成新结点s->data = e;s->next = p->next;//插入L中p->next = s;
}

删除元素

//算法2.10 函数ListDelete在单链表中的实现
Status ListDelete_L(LinkList& L, int i, ElemType& e) {//在带头结点的单链线性表L中,删除第i个元素,并由e返回其值LinkList p = L;int j = 0;while (p && j < i - 1) {p = p->next;++j;//寻找第i个结点,p->next所在的位置}if (!(p->next) || j > i - 1)return ERROR;//删除位置不合理LinkList q = p->next;p->next = q->next;//删除并释放结点e = q->data;free(q);return OK;
}

头插法建立单链表

//算法2.11 头插法建立单链表
void CreateList_L(LinkList& L, int n) {//逆位序输入n个元素的值,建立带表头结点的单链线性表L。L = (LinkList)malloc(sizeof(LNode));L->next = NULL;//先建立一个带头结点的单链表LinkList p;for (int i = n;i > 0;i--) {p = (LinkList)malloc(sizeof(LNode));scanf_s("%d", &p->data);//输入元素值p->next = L->next;//插入到表头L->next = p;//插入到表尾// LinkList T=L;// for循环,用下面三行替换插入表头两行//p->next=NULL;//T->next=p;//T=p;}
}

合并非递减单链表

//算法2.12 合并非递减单链表
void MergeList_L(LinkList& La, LinkList& Lb, LinkList& Lc) {//已知顺序线性表La和Lb的元素按值非递减排列//归并La和Lb得到的新的顺序线性表Lc,Lc的元素也按值非递减排列LinkList pa = La->next;LinkList pb = Lb->next;LinkList pc = Lc = La;//用La的头结点作为Lc的头结点while (pa && pb) {if (pa->data <= pb->data) {pc->next = pa;pc = pa;pa = pa->next;}else {pc->next = pb;pc = pb;pb = pb->next;}}pc->next = pa ? pa : pb;//插入剩余段free(Lb);//释放Lb的头结点
}

free函数不能放在while循环内,否则会出现以下情况。

警告信息:使用未初始化的内存"Lb"。

看不懂,但这个问题解决了。

其他基本操作

void PrintList_L(LinkList L) {//打印链表LinkList p = L->next;while (p) {//while(p=p->next)这样写行吗?printf("%d ", p->data);p = p->next;}printf("\n");
}Status DestroyList_L(LinkList& L) {//销毁链表LinkList p;while (L) {p = L;L = L->next;free(p);//free函数的释放是只释放一个结点,还是释放后面相关的所有结点?--已解决,只释放一个结点。}return OK;
}

完整版

#pragma once
#include <cstdio>
#include <cstdlib>
#include <cstring>#define TRUE 1
#define FALSE 0
#define OK 1
#define ERROR 0
#define INFEASIBLE -1
#define OVERFLOW -2
typedef int Status;//Status是函数的类型,其值是函数结果状态代码
typedef int ElemType;//-----线性表的单链表存储结构-----
typedef struct LNode {ElemType data;struct LNode* next;
}LNode,*LinkList;//算法2.11 头插法建立单链表
void CreateList_L(LinkList& L, int n) {//逆位序输入n个元素的值,建立带表头结点的单链线性表L。L = (LinkList)malloc(sizeof(LNode));L->next = NULL;//先建立一个带头结点的单链表LinkList p;for (int i = n;i > 0;i--) {p = (LinkList)malloc(sizeof(LNode));scanf_s("%d", &p->data);//输入元素值p->next = L->next;//插入到表头L->next = p;//插入到表尾// LinkList T=L;// for循环,用下面三行替换插入表头两行//p->next=NULL;//T->next=p;//T=p;}
}//算法2.8 函数GetElem在单链表中的实现。
Status GetElem_L(LinkList L, int i, ElemType& e) {//L为带头结点的单链表的头指针。//当第i个元素存在时,其值赋给e并返回OK,否则返回ERRORLinkList p = L->next;int j = 1;//初始化,p指向第一个结点,j为计数器while (p && j < i) {//顺指针向后查找,直到p指向第i个元素或p为空p = p->next;++j;}if (!p || j > i)return ERROR;//第i个元素不存在e = p->data;//取第i个元素return OK;
}//算法2.9 函数ListInsert在单链表中的实现
Status ListInsert_L(LinkList& L, int i, ElemType e) {//在带头结点的单链线性表L中第i个位置之前插入元素eLinkList p = L;int j = 0;while (p && j < i - 1) {p = p->next;++j;//寻找第i-1个结点}if (!p || j > i - 1)return ERROR;//i小于1或者大于表长+1LinkList s = (LinkList)malloc(sizeof(LNode));//生成新结点s->data = e;s->next = p->next;//插入L中p->next = s;
}//算法2.10 函数ListDelete在单链表中的实现
Status ListDelete_L(LinkList& L, int i, ElemType& e) {//在带头结点的单链线性表L中,删除第i个元素,并由e返回其值LinkList p = L;int j = 0;while (p && j < i - 1) {p = p->next;++j;//寻找第i个结点,p->next所在的位置}if (!(p->next) || j > i - 1)return ERROR;//删除位置不合理LinkList q = p->next;p->next = q->next;//删除并释放结点e = q->data;free(q);return OK;
}//算法2.12 合并非递减单链表
void MergeList_L(LinkList& La, LinkList& Lb, LinkList& Lc) {//已知顺序线性表La和Lb的元素按值非递减排列//归并La和Lb得到的新的顺序线性表Lc,Lc的元素也按值非递减排列LinkList pa = La->next;LinkList pb = Lb->next;LinkList pc = Lc = La;//用La的头结点作为Lc的头结点while (pa && pb) {if (pa->data <= pb->data) {pc->next = pa;pc = pa;pa = pa->next;}else {pc->next = pb;pc = pb;pb = pb->next;}}pc->next = pa ? pa : pb;//插入剩余段free(Lb);//释放Lb的头结点
}void PrintList_L(LinkList L) {//打印链表LinkList p = L->next;while (p) {//while(p=p->next)这样写行吗?printf("%d ", p->data);p = p->next;}printf("\n");
}Status DestroyList_L(LinkList& L) {//销毁链表LinkList p;while (L) {p = L;L = L->next;free(p);//free函数的释放是只释放一个结点,还是释放后面相关的所有结点?--已解决,只释放一个结点。}return OK;
}

测试代码(主函数)

#include "LinkList.h"int main()
{LinkList La = NULL,Lb = NULL,Lc = NULL;int n1,n2;Status i = 0;ElemType e;//变量声明//测试算法2.11printf("请输入元素个数:");//构建单链表Lascanf_s("%d", &n1);printf("请输入元素:");CreateList_L(La, n1);printf("\n");printf("头插法得到的元素逆序:");PrintList_L(La);//测试算法2.8i = GetElem_L(La, 3, e);if (i)printf("第3个元素为%d\n", e);elseprintf("第3个元素不存在\n");//测试算法2.9,2.10.i = ListInsert_L(La, 3, 3);if (i)printf("插入成功\n");elseprintf("插入失败\n");i = ListDelete_L(La, 5, e);if (i)printf("删除成功\n");elseprintf("删除失败\n");//测试算法2.12printf("请输入元素个数:");//构建单链表Lbscanf_s("%d", &n2);printf("请输入元素:");CreateList_L(Lb, n2);printf("\n");printf("头插法得到的元素逆序:");PrintList_L(Lb);MergeList_L(La, Lb, Lc);printf("新链表的元素:");PrintList_L(Lc);DestroyList_L(Lc);//因为Lc实质是La和Lb的合并,而且Lb的头结点已经被释放了。return 0;
}

测试结果

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/644454.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

GBASE南大通用数据库通过 GBase ADO.NET 接口读取数据

通过 GBase ADO.NET 接口读取 GBase Server 数据需要下面的步骤&#xff1a; 1) 使用 GBaseConnection 创建数据库连接对象 2) 使用 GBaseCommand 创建命令对象 3) 使用连接对象打开连接 4) 设置命令对象的 CommandText 属性&#xff0c;指明查询语句&#xff0c;并关联连接对…

html+css+javascript实现贪吃蛇游戏

文章目录 一、贪吃蛇游戏二、JavaScript三、HTML四、CSS五、热门文章 一、贪吃蛇游戏 这是一个简单的用HTML、CSS和JavaScript实现的贪吃蛇游戏示例。 HTML部分&#xff1a; <!DOCTYPE html> <html> <head><title>贪吃蛇游戏</title><styl…

【C++】命名空间详解

目录 前言 命名空间的定义 命名空间的使用 前言 在C/C中&#xff0c;变量、函数和后面要学到的类都是大量存在的&#xff0c;这些变量、函数和类的名称将都存 在于全局作用域中&#xff0c;可能会导致很多冲突。使用命名空间的目的是对标识符的名称进行本地化&#xff0c; 以…

【LeetCode力扣】面试题 17.14. 最小K个数(top-k问题)

目录 1、题目介绍 2、解题思路 2.1、优先队列解法 2.2、top-k问题解法 1、题目介绍 原题链接&#xff1a;面试题 17.14. 最小K个数 - 力扣&#xff08;LeetCode&#xff09; 题目要求非常简短&#xff0c;也非常简单&#xff0c;就是求一组数中的k个最小数。 2、解题思路 …

数据结构:完全二叉树(递归实现)

如果完全二叉树的深度为h&#xff0c;那么除了第h层外&#xff0c;其他层的节点个数都是满的&#xff0c;第h层的节点都靠左排列。 完全二叉树的编号方法是从上到下&#xff0c;从左到右&#xff0c;根节点为1号节点&#xff0c;设完全二叉树的节点数为sum&#xff0c;某节点编…

【重点问题】攻击面发现及管理

Q1&#xff1a;在使用长亭云图极速版时&#xff0c;是否需要增设白名单扫描节点&#xff1f; 长亭云图极速版高级网络安全产品基于一种理念&#xff0c;即攻击面发现是一个不断变换且需要持续对抗的过程。在理想的情况下&#xff0c;用户应当在所有预置防护设施发挥作用的环境…

C++面试:stl的栈和队列介绍

目录 栈 栈&#xff08;stack&#xff09;的声明&#xff1a; push()&#xff1a; 将元素推入栈顶 pop()&#xff1a; 弹出栈顶元素 top()&#xff1a; 访问栈顶元素&#xff0c;但不弹出 empty()&#xff1a; 检查栈是否为空 size()&#xff1a; 返回栈中元素的数量 …

【MQ01】什么是消息队列?用哪个消息队列?

什么是消息队列&#xff1f;用哪个消息队列&#xff1f; 来了来了&#xff0c;消息队列系列总算来咯。对于搜索引擎相关的知识大家消化的怎么样呀&#xff1f;其实对于搜索引擎来说&#xff0c;我们学习的内容还是挺全面的&#xff0c;也算是比较深入了。而对于消息队列来说&am…

6.第一个Python爬虫程序

使用 Python 内置的 urllib 库获取网页的 html 信息。注意&#xff0c;urllib 库属于 Python 的标准库模块&#xff0c;无须单独安装&#xff0c;它是 Python 爬虫的常用模块 获取网页html信息 1) 获取响应对象 向百度&#xff08;百度一下&#xff0c;你就知道&#xff09;…

uniapp使用uni-forms表单校验无效

查看是否写了name属性&#xff0c;且name属性的属性值得和下面v-model绑定的一致&#xff0c;否则校验不生效 官网

一种解决常用存储设备无法被电脑识别的方法

一、通用串行总线控制器描述 通用串行总线&#xff08;Universal Serial Bus&#xff0c;简称USB&#xff09;&#xff0c;是连接电脑与设备的一种序列总线标准&#xff0c;也是一种输入输出&#xff08;I/O&#xff09;连接端口的技术规范&#xff0c;广泛应用于个人电脑和移动…

关于大模型学习中遇到的4

来源&#xff1a;网络 相关学习可查看文章&#xff1a;Transformer and Pretrain Language Models3-4​​​​​​​ 什么是MLP? MLP是多层感知器&#xff08;Multilayer Perceptron&#xff09;的缩写&#xff0c; 多层感知机&#xff08;MLP&#xff09;是一种人工神经网…

【C++】初步认识基于C的优化

C祖师爷在使用C语言时感觉到了不方便的一些点&#xff0c;于是一步一步改进优化&#xff0c;最后形成了C 本文将盘点一下基于C的语法优化 目录 命名空间&#xff1a;命名空间定义&#xff1a;命名空间使用&#xff1a; C输入&输出&#xff1a;cout&#xff1a;endl&#…

vue项目开发的完整流程

一.构建vue.js项目 1. 安装node https://nodejs.org/en/ 下载完成后&#xff0c;下一步–>下一步–>安装完成 验证node是否安装成功: 打开命令行(windows)或终端(mac),在命令行(终端)中输入&#xff1a; node -v 如果提示出版本信息则说明node安装成功 npm -v 如果提示出…

使用django-admin来做erp,是否需要使用缓存数据库

需求: 因为添加了手机字段作为加密方式存储&#xff0c; 每次管理员查看所有订单时&#xff0c;将会进行手机字段的解密&#xff0c;那么在这个时候就会消耗多几秒. 那么计划提供一个缓存数据库给django结论&#xff1a;仅仅使用django admin&#xff0c;不需要使用缓存 1&…

C语言每日一题(47)两数相加II

力扣 445 两数相加II 题目描述 给你两个 非空 链表来代表两个非负整数。数字最高位位于链表开始位置。它们的每个节点只存储一位数字。将这两数相加会返回一个新的链表。 你可以假设除了数字 0 之外&#xff0c;这两个数字都不会以零开头。 示例1&#xff1a; 输入&#xff…

全覆盖规划算法学习笔记-------

ROS全覆盖规划算法 通过对比提供的ROS全覆盖规划算法&#xff1a;确定Boustrophedon Planner和Grid-based Local Energy Minimization Planner具备过程应用价值&#xff0c;这里选择后者进行重点研究。 参考&#xff1a; 官网 ipa_room_exploration - ROS Wiki Indoor Cover…

(2024,强化学习,扩散,奖励函数)扩散模型的大规模强化学习

Large-scale Reinforcement Learning for Diffusion Models 公和众和号&#xff1a;EDPJ&#xff08;进 Q 交流群&#xff1a;922230617 或加 VX&#xff1a;CV_EDPJ 进 V 交流群&#xff09; 目录 0. 摘要 3. 方法 3.1. 使用多步骤 MDP 的策略梯度 3.2. 基于分布的奖励函…

2023 中国互联网公司 Top 100 排行榜

中国互联网协会发布了《中国互联网企业综合实力指数&#xff08;2023&#xff09;》报告&#xff0c;来源&#xff1a;https://www.isc.org.cn/article/18458024914186240.html 预览如下&#xff1a; 这份报告总结了互联网公司的排名&#xff0c;毫不意外&#xff0c;腾讯、阿里…

设计模式⑧ :管理状态

文章目录 一、前言二、Observer 模式1. 介绍2. 应用3. 总结 三、Memento 模式1. 介绍2. 应用3. 总结 四、State 模式1. 介绍2. 应用3. 总结 参考文章 一、前言 有时候不想动脑子&#xff0c;就懒得看源码又不像浪费时间所以会看看书&#xff0c;但是又记不住&#xff0c;所以决…