数据结构实现-线性表

顺序存储

#include<iostream>
using namespace std;
#define MaxSize 50
//静态顺序表
template<typename ElemType>
struct sqList{ElemType data[MaxSize];//元素int length;//长度
};
//动态顺序表
#ifdef DEBUG //关闭启用
#define InitSize 100
template<typename ElemType>
struct seqList {ElemType* data;//元素int MaxSize;//最大容量int length;//长度
};
#endif // DEBUG//插入操作
template<typename ElemType>
/**	@param L 顺序表*	@param i 插入位置(从1开始)*	@param e 插入元素
*/
bool ListInsert(sqList<ElemType>& L, int i, ElemType e) {if (i<1 || i>L.length + 1)//判断插入范围是否合理(第1个元素到最后一个元素的下一个)return false;if (L.length >= MaxSize)//顺序表长度大于最大长度return false;for (int j = L.length; j >= i; --j) {//移动顺序表L.data[j] = L.data[j - 1];}L.data[i - 1] = e;//插入++L.length;  //长度+1return true; //表示插入成功
}//删除操作
template<typename ElemType>
/**	@param L 顺序表*	@param i 删除位置(从1开始)*	@param e 插入元素
*/
bool ListDelete(sqList<ElemType>& L, int i, ElemType& e) {if (i<1 || i>L.length) //删除元素下标范围return false;e = L.data[i - 1];  //复制删除内容for (int j = i ; j < L.length; ++j) {L.data[j - 1] = L.data[j];}--L.length; //顺序表长度-1return true; //操作成功
}//按值查找(顺序查找)
template<typename ElemType>
/**	@param L 顺序表*	@param e 查找元素
*/
int LocalElem(sqList<ElemType>& l, ElemType& e) {int i;for (i = 0; i < l.length; ++i) {if (l.data[i] == e) //找到待查找元素下标return i + 1;}return 0;
}

链式存储

#include<iostream>
using namespace std;//链表节点
template<typename ElemType>
struct LNode {ElemType data;//元素struct LNode *next;//长度
};//头插法建立链表
template<typename ElemType>
/**	@param L 顺序表
*/
LNode<ElemType>* List_HeadInsert(LNode<ElemType>* L) {LNode<ElemType>* s; ElemType x;L = new LNode<ElemType>;L->next = nullptr;cin >> x;while (x != 9999) {s = new LNode<ElemType>;s->data = x;s->next = L->next;L->next = s;cin >> x;}return L;
}//尾插法建立链表
template<typename ElemType>
/**	@param L 顺序表
*/
LNode<ElemType>* List_TailInsert(LNode<ElemType>* L) {ElemType x;L = new LNode<ElemType>;LNode<ElemType>* s, * r = L;cin >> x;while (x != 9999) {s = new LNode<ElemType>;s->data = x;r->next = s;r = s;cin >> x;}r->next = nullptr;return L;
}//按序号查找结点
template<typename ElemType>
/**	@param L 顺序表*	@param i 位置(从1开始)
*/
LNode<ElemType>* GetElem(LNode<ElemType>*L, int i) {if (i < 1)return nullptr;int j = 1;LNode<ElemType>* p = L->next;while (p != nullptr && j < i) {p = p->next;++j;}return p;
}//按值查找节点
template<class ElemType>
/**	@param L 顺序表*	@param e 插入元素
*/
LNode<ElemType>* LocateElem(LNode<ElemType>* L, ElemType e) {LNode<ElemType>* p = L;while (p!=nullptr&&p->data!=e){p = p->next;}return p;
}//在第i个前插入节点
template<class ElemType>
/**	@param L 顺序表*	@param i 插入位置(从1开始)*	@param e 插入元素
*/
bool Front_Insert(LNode<ElemType>* L, int i, ElemType e) {LNode<ElemType>* temp = GetElem(L, i - 1);if (temp == nullptr)return false;LNode<ElemType>* newNode = new LNode<ElemType>;newNode->data = e;newNode->next = temp->next;temp->next = newNode;return true;
}//删除第i个节点
template<class ElemType>
/**	@param L 顺序表*	@param i 位置(从1开始)
*/
bool Delete(LNode<ElemType>* L, int i) {LNode<ElemType>* temp = GetElem(L, i - 1);if (temp == nullptr)return false;LNode<ElemType>* next = temp->next;temp->next = temp->next->next;delete next;return true;
}//获取链表长度
template<class ElemType>
/**	@param L 顺序表
*/
int GetLinkLength(LNode<ElemType>* L) {int cnt = 0;LNode<ElemType>* cur = L->next;while (cur){++cnt;cur = cur->next;}return cnt;
}

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

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

相关文章

嵌入式LINUX移植、配置ssh

编译 https://quantum6.blog.csdn.net/article/details/136299665 编译时指定prefix&#xff0c;产生的文件会自带这个目录。所以直接忽略。 ./configure# 不指定编译路径&#xff0c;手动复制。 复制 编译后的整个目录打包&#xff0c;复制到开发板。写个脚本&#xff0c…

kamacoder13.镂空三角形的C语言解法

13. 镂空三角形 时间限制&#xff1a;1.000S 空间限制&#xff1a;32MB 题目描述 把一个字符三角形掏空&#xff0c;就能节省材料成本&#xff0c;减轻重量&#xff0c;但关键是为了追求另一种视觉效果。在设计的过程中&#xff0c;需要给出各种花纹的材料和大小尺寸的三角…

零拷贝技术深入分析

一、零拷贝 在前面的文章“深浅拷贝、COW及零拷贝”中对零拷贝进行过分析&#xff0c;但没有举例子&#xff0c;也没有深入进行展开分析。本文将结合实际的例程对零拷贝进行更深入的分析和说明。 在传统的IO操作中&#xff0c;以文件通过网络传输为例 &#xff0c;一般会经历以…

go语言是如何连接mysql数据库的?

在 Go 语言中连接 MySQL 数据库通常使用第三方库。目前比较流行的 MySQL 客户端库包括 github.com/go-sql-driver/mysql、github.com/go-xorm/xorm、github.com/jmoiron/sqlx 等。下面是一个使用 github.com/go-sql-driver/mysql 库连接 MySQL 数据库的简单示例&#xff1a; 首…

GOPATH set to GOROOT (/usr/local/go) has no effect

这个警告信息指出 GOPATH 环境变量被设置为与 GOROOT 相同的值。GOPATH 环境变量用于指定 Go 工作区的位置&#xff0c;而 GOROOT 指定 Go 安装的位置。将 GOPATH 设置为 GOROOT 表示 Go 工作区和 Go 安装位置位于同一目录&#xff0c;这是不推荐的。为了解决此问题&#xff0c…

Zookeeper集群docker部署

集群角色 zookeeper 集群中的机器分为一下三种角色 leader:为客户端提供读写服务(事务性操作)&#xff0c;并维护集群状态&#xff0c;它是由集群选举所产生的&#xff1b; follower:为客户端提供读(非事务性操作)&#xff0c;转发给leader写(事务性操作)&#xff0c;参与选举操…

K8s控制器

控制器: Deployment: Deployment概述: replicaset:自动创建pod的控制器 Delpoyment控制器: pod的名字需要唯一,在这不写名字,利用标签进行创建 replicas:表示你想要克隆的数量,selector:通过标签.识别哪个pod是我创建出来的.这里的标签和后面元数据里的标签要一致. Cluster…

NCDA设计大赛获奖作品剖析:UI设计如何脱颖而出?

第十二届大赛简介 - 未来设计师全国高校数字艺术设计大赛&#xff08;NCDA&#xff09;开始啦&#xff01;视觉传达设计命题之一: ui 设计&#xff0c;你想知道的都在这里。为了让大家更好的参加这次比赛&#xff0c;本文特别为大家整理了以往NCDA大赛 UI 设计的优秀获奖作品&a…

【探索AI】十四深度学习之第2周:深度神经网络(三)-过拟合与正则化技术

过拟合与正则化技术 过拟合的概念 在机器学习和深度学习的领域中&#xff0c;过拟合&#xff08;Overfitting&#xff09;是一个常见且重要的问题。首先&#xff0c;我们来理解一下什么是过拟合。 过拟合是指模型在训练数据上表现得过于优秀&#xff0c;以至于在训练集上的错…

2024年腾讯云优惠券_代金券_云服务器折扣券免费领取链接

腾讯云优惠代金券领取入口共三个渠道&#xff0c;腾讯云新用户和老用户均可领取8888元代金券&#xff0c;可用于云服务器等产品购买、续费和升级使用&#xff0c;阿腾云atengyun.com整理腾讯云优惠券&#xff08;代金券&#xff09;领取入口、代金券查询、优惠券兑换码使用方法…

【SpringBean】bean的作用域和bean的生命周期

目录 前言 一 bean的作用域 1. singleton——唯一 bean 实例 2. prototype——每次请求都会创建一个新的 bean 实例 3. request——每一次HTTP请求都会产生一个新的bean&#xff0c;该bean仅在当前HTTP request内有效 4. session——每一次HTTP请求都会产生一个新的 bean&…

程序员的金三银四求职宝典!

目录 ​编辑 程序员的金三银四求职宝典 一、为什么金三银四是程序员求职的黄金时期&#xff1f; 二、如何准备金三银四求职&#xff1f; 1. 完善简历 2. 增强技术能力 3. 提前考虑目标公司 4. 提前准备面试 三、程序员求职的常见面试题 1. 数据结构和算法 2. 数据库 …

一次电脑感染Synaptics Pointing Device Driver病毒的经历,分享下经验

没想到作为使用电脑多年的老司机也会电脑中病毒&#xff0c;周末玩电脑的时候突然电脑很卡&#xff0c;然后自动重启&#xff0c;奇怪&#xff0c;之前没出现这个情况。 重启后电脑开机等了几十秒&#xff0c;打开任务管理器查看开机进程&#xff0c;果然发现有个Synaptics Po…

LeetCode 刷题 [C++] 第121题.买卖股票的最佳时机

题目描述 给定一个数组 prices &#xff0c;它的第 i 个元素 prices[i] 表示一支给定股票第 i 天的价格。 你只能选择 某一天 买入这只股票&#xff0c;并选择在 未来的某一个不同的日子 卖出该股票。设计一个算法来计算你所能获取的最大利润。 返回你可以从这笔交易中获取的…

php儿童服装销售管理系统计算机毕业设计项目包运行调试

php mysql儿童服装销售网 功能&#xff1a;前台后台 前台&#xff1a; 1.服装资讯 文章标题列表 详情 2.服装选购中心 分页查看图文列表 详情 3.用户注册 登陆 退出 4.服装加入收藏 5.加入购物车 6.对服装进行评论 会员中心&#xff1a; 1.我的账户 查看 修改 2.我的收藏 查看 …

STM32 中断流程介绍

STM32可以产生中断的事件多种多样&#xff0c;比如&#xff1a;定时器时间结束、串口接收到数据、某个GPIO检测到电平变化等等等等。 1、STM32 gpio 中断处理流程介绍 1、从引脚进入的高低电平首先由输入驱动器处理&#xff0c;如下图 2、经过输入驱动器处理后的信号会进…

大数据数据平台的数仓体系分类有哪些?

大数据平台的数仓体系最初由数据库发展而来&#xff0c;主要分为三类架构&#xff0c;分别是Shared-Nothing、Shared-Data、Shared-Everything。 Shared-Nothing&#xff08;也称 MPP&#xff09;架构在 很长一段时间成为主流。 随云原生能力增强&#xff0c;Snowflake 为代表…

c++基础知识补充4

单独使用词汇 using std::cout; 隐式类型转换型初始化&#xff1a;如A a1,,此时可以形象地理解为int i1;double ji;&#xff0c;此时1可以认为创建了一个值为1的临时对象&#xff0c;然后对目标对象进行赋值&#xff0c;当对象为多参数时&#xff0c;使用&#xff08;1&#xf…

c1-周考2

c1-第二周 9月-技能1.一个岛上有两种神奇动物&#xff0c;其中神奇鸟类2个头3只脚&#xff0c;神奇兽类3个头8只脚。游客在浓雾中看到一群动物&#xff0c;共看到35个头和110只脚&#xff0c;求可能的鸟类和兽类的只数2.构建一个长度为5的数组&#xff0c;并且实现下列要求3.构…

鬼屋游戏c++

c #include <iostream> #include <string> #include <vector> #include <cstdlib> // 用于随机数生成 #include <ctime> // 用于随机数种子using namespace std;// 定义房间结构体 struct Room {string description;bool hasKey;bool hasClue…