数据结构之顺顺顺——顺序表

1.浅谈数据结构

     相信我们对数据结构都不陌生,我们之前学过的数组就是最基础的数据结构,它大概就长这样:

数组

       而作为最简单的数据结构,数组只能帮助我们实现储存数据这一个功能,随着学习的深入,和问题的日渐复杂,最基础的已经不能完全满足我们复杂的算法实现,于是我们需要学习更进阶的数据结构来实现我们对数据的增删查改等一系列操作。 

       我们回顾一下数据结构的定义:它是计算机中存储、组织和管理数据的方式。它定义了数据的表示方式、操作和存储方式,以及数据之间的关系。

       说人话就是:1.能够存储数据(如顺序表,链表等)

                             2.存储的数据可以方便的查找出来

       顺序表就是这样一种数据结构,比数组更复杂,可以更好满足我们的需求。但事实上顺序表的底层还是数组,它是对数组的封装,实现了常用的增删查找的接口。

2.顺序表

2.1顺序表的定义

        顺序表(Sequential List)是线性表的一种,它是将数据元素按照一定的顺序依次存放在一段连续的存储单元中,物理结构不一定是线性的,但逻辑结构一定是线性的。

补充一点芝士:

线性表(linear list )是n个具有相同特性的数据元素的有限序列。 线性表是一种在实际中广泛使用的数据结构,常见的线性表:顺序表、链表、栈、队列、字符串...线性表在逻辑上是线性结构,也就说是连续的一条直线。但是在物理结构上并不一定是连续的,线性表在物理上存储时,通常以数组和链式结构的形式存储。

 2.2顺序表的分类

1)静态顺序表

概念:使用定长数组储存元素

静态顺序表缺陷:给小了,空间不够用;给大了,空间浪费。

于是就有了下面的动态表。

2)动态顺序表 

2.3动态顺序表的实现 

//动态顺序表
typedef struct SeqList
{SLDataType* arr;int size; //有效数据个数int capacity; //空间大小
}SL;//typedef struct SeqList SL;//顺序表初始化
void SLInit(SL* ps);
//顺序表的销毁
void SLDestroy(SL* ps);
void SLPrint(SL s);//头部插入删除 / 尾部插入删除
void SLPushBack(SL* ps, SLDataType x);
void SLPushFront(SL* ps, SLDataType x);void SLPopBack(SL* ps);
void SLPopFront(SL* ps);//指定位置之前插入/删除/查找数据
void SLInsert(SL* ps, int pos, SLDataType x);
void SLErase(SL* ps, int pos);
int SLFind(SL* ps, SLDataType x);

     后面会详细讲这些实现是如何操作的~~~

   🎈🎈完结撒花🎈🎈

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

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

相关文章

React | React.cloneElement 的使用

我看到同事的代码里有 cloneElement,于是去了解了一下这个函数。 就跟它的名字一样,克隆元素,可以基于一个元素创建一个新的元素,并且为新元素添加新的属性或者覆盖已有的属性。 下面是一个简单例子: .node1 {backg…

Java集合框架-Collection-queue

目录 一、Deque二、ArrayDequeArrayDeque层次结构图ArrayDeque概述ArrayDeque底层数据结构ArrayDeque常用方法(简略) 三、PriorityQueuePriorityQueue层次结构图PriorityQueue概述PriorityQueue 底层数据结构PriorityQueue常用方法(详细) Java里有一个叫做Stack的类&#xff0c…

【Linux】进程的控制①之进程创建与进程退出

一 、进程的创建 1、fork函数 fork函数功能:从已经存在的进程中创建一个新进程。新进程为子进程,原进程为父进程。 fork函数创建进程过后,父子进程代码和数据是共享的。在前面也讲过。 2.函数的返回值 如果进程创建成功,给父进…

Linux中的vi与vim:编辑器的王者之争与深度探索

🐇明明跟你说过:个人主页 🏅个人专栏:《Linux :从菜鸟到飞鸟的逆袭》🏅 🔖行路有良友,便是天堂🔖 目录 一、前言 1、Linux的起源与发展 2、vi与vim的历史与发展 …

【ARMv9 DSU-120 系列 6 -- Power management】

请阅读【Arm DynamIQ™ Shared Unit-120 专栏 】 文章目录 Power management In DSU-120Power DomainsPDTopPDClusterPDCore<cn>PDComplex<cpxn>PDSlice<slicen>PDL3RAM0 和 PDL3RAM1Cluster power mode在线模式(On)

flutter笔记-webrtc使用1:依赖本地包socket.io-client

文章目录 1. 示例工程2. yaml 修改3. 使用4. socketio 关于自定义服务器自定义签名的问题封装成async和await方式 本文开始介绍webrtc的使用&#xff0c;阅读本文的前提是假设你已经使用过webrtc&#xff0c;了解webrtc的交互机制&#xff0c;不了解的可以看之前的文章&#xf…

springboot实现同时批量新增和批量修改数据

在springboot项目中&#xff0c;实现同时将一批数据进行新增和修改 有时候我们会遇到&#xff0c;用户在前端界面提交一批数据&#xff0c;而这一批数据中&#xff0c;可能有新增的数据也可能存在修改的数据&#xff0c;为了方便同时执行新增和修改的方法&#xff0c;需要调用…

Python轻量级Web框架Flask(12)—— Flask类视图实现前后端分离

0、前言&#xff1a; 在学习类视图之前要了解前后端分离的概念&#xff0c;相对于之前的模板&#xff0c;前后端分离的模板会去除views文件&#xff0c;添加两个新python文件apis和urls&#xff0c;其中apis是用于传输数据和解析数据 的&#xff0c;urls是用于写模板路径的。 …

数据库介绍(Mysql安装)

前言 工程师再在存储数据用文件就可以了&#xff0c;为什么还要弄个数据库? 一、什么是数据库&#xff1f; 文件保存数据有以下几个缺点&#xff1a; 文件的安全性问题文件不利于数据查询和管理文件不利于存储海量数据文件在程序中控制不方便 数据库存储介质&#xff1a; 磁…

【UE C++】设置游戏模式

问题 我们都知道如何使用蓝图创建一个游戏模式并且在这个游戏模式蓝图中去设置“默认pawn类”、“HUD类”、“玩家控制器类”、“游戏状态类”、“玩家状态类”、“旁观者类”。那么如何使用C完成该操作呢&#xff1f; 步骤 1. 首先创建“GameMode”、“GameState”、“HUD”…

Arthas:阿里出品,线上问题快速搞定!

前面我们通过JVM线程分析及内存分析来让大家从服务器资源异常情况下排查代码问题&#xff0c;类似这种的解决方式&#xff0c;更多的是在服务器资源占用已经异常显现&#xff0c;我们就可以按照这种方式去排查和解决。 但实际工作中&#xff0c;可能会出现&#xff1a;接口的TP…

惯导中基本的目标参数及其过程量

目标参数过程量(过程噪声&#xff09;目标参数物理含义常用单位过程量物理含义过程量物理对象单位功率谱密度单位(psd)rand walk error过程量目标参数/tunitpsd(unit)^2/hzsqrt(psd)常用单位单位换算速度(m/s)加速度m/s^2m^2/s^3m/s/sqrt(s)m/s/sqrt(hr)ug/sqrt(HZ)角度(rad)角…

boost::asio::io_context, boost::asio::steady_timer

asio::io_context是Asio库中的一个I/O执行环境&#xff0c;而asio::steady_timer是一个与asio::io_context关联的定时器&#xff0c;可以用来在给定的时间点执行一个函数或者是在一个固定的时间间隔后执行一个函数。 以下是一个创建asio::steady_timer的例子 #include <ios…

Paddle OCR v4 微调训练文字识别SVTRNet模型实践

文字识别步骤参考&#xff1a;https://github.com/PaddlePaddle/PaddleOCR/blob/main/doc/doc_ch/recognition.md 微调步骤参考:https://github.com/PaddlePaddle/PaddleOCR/blob/release/2.7.1/doc/doc_ch/finetune.md 训练必要性 原始模型标点符号和括号容易识别不到 数据…

自动化机器学习:让机器学习更智能

自动化机器学习&#xff1a;让机器学习更智能 在当今数据驱动的时代&#xff0c;机器学习技术已经成为了许多行业和领域的核心。然而&#xff0c;随着数据量的增加和模型复杂度的提升&#xff0c;传统的机器学习方法往往需要大量的人力和时间进行调参和优化&#xff0c;这在某…

3步教你成为微信客户管理高手,助你事半功倍!

在如今的商业世界中&#xff0c;与客户建立良好的关系并提供个性化的服务已成为企业成功的关键。今天就 分享三个简单的步骤&#xff0c;让大家成为微信客户管理的高手&#xff0c;事半功倍&#xff01; 第一步&#xff1a;客户分类与精细化服务 为了更好地管理客户&#xff…

ROS2 ZEDX UBUNTU 环境配置

一、环境要求 硬件&#xff1a;镭神域控 ZED X双目摄像机 ros2-foxy zed sdk 4.0.8 cuda 11.4 二、CUDAZED SDK安装 安装显卡驱动以及CUDA 11.1 参考之前博文&#xff1a; https://blog.csdn.net/qq_41950533/article/details/135673420?csdn_share_tail%7B%22type%22%3A%2…

mongodb使用debezium

前置 服务器上需要安装jdk11 jdk下载地址 kafka安装 官网下载地址 安装教程 debezium 安装 运行 Debezium 连接器需要 Java 11 或更高版本 Debezium 并不是一个独立的软件&#xff0c;而是很多个 Kafka 连接器的总称。这些 Kafka 连接器分别对应不同的数据库&#xff0c;…

【C++】C\C++内存管理

下面是围绕C\C内存管理这一块知识谈论相关的内存管理机制&#xff0c;有需要借鉴即可。 同时&#xff0c;我在下面也放了快速建立链表的模板&#xff0c;方便oj题目拿到vs上进行调试。 内存管理目录 1.CPP内存管理1.1new、delete关键字概念1.2特性1.3总结 2.new、delete的底层…

电商API数据采集接口||大数据的发展,带动电子商务产业链,促进了社会的进步

最近几年计算机技术在诸多领域得到了有效的应用&#xff0c;同时在多方面深刻影响着我国经济水平的发展。除此之外&#xff0c;人民群众的日常生活水平也受大数据技术的影响。 主流电商API数据采集接口||在这其中电子商务领域也在大数据技术的支持下&#xff0c;得到了明显的进…