【数据结构】02.顺序表

一、顺序表的概念与结构

1.1线性表

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

1.2顺序表分类

1.2.1 顺序表和数组的区别

顺序表的底层结构是数组,对数组的封装,实现了常用的增删改查等接口

1.2.2顺序表分类

  • 静态顺序表

概念:使用定长数组存储元素
在这里插入图片描述
静态顺序表缺陷:空间给少了不够用,给多了造成空间浪费

  • 动态顺序表

在这里插入图片描述

二、动态顺序表的实现

2.1结构体表示顺序表

首先需要一个结构体来表示顺序表:

typedef int SLDataType;//笔者在此直接使用了接下来要实现的顺序表的数据类型
//顺序表结构体
typedef struct SL
{SLDataType* a;int size;int capacity;
}SL;

2.2顺序表的初始化和销毁

//初始化顺序表
void init(SL* s)
{s->a = NULL;s->size = s->capacity = 0;
}
//顺序表销毁
void SLDestory(SL* s)
{assert(s);if(s->a){free(s->a);}s->a = NULL;s->size = s->capacity = 0;
}

2.3顺序表的增删查改

在每次插入时都会面对着是否扩容的问题,因此我们抽离出检查扩容的函数

//检查是否满了
void check(SL* s)
{if (s->size == s->capacity){int new_capacity = (s->capacity == 0) ? 4 : s->capacity * 2;SLDataType* temp = (SLDataType*)realloc(s->a, sizeof(SLDataType) * new_capacity);if (temp == NULL){perror("realloc is fail!");//如果realloc失败会报错exit (EXIT_FAILURE);}s->a = temp;s->capacity =new_capacity;}
}
//头插
void PushFront(SL* s, SLDataType x)
{assert(s);check(s);for (int i =s->size;i>0;i--){s->a[i] =s->a[i-1];}s->a[0] = x;s->size++;
}//尾插
void PushBack(SL* s, SLDataType x)
{assert(s);check(s);s->a[s->size] = x;s->size++;
}//头删
void PopFront(SL* s)
{assert(s && s->size);for (int i =0;i<s->size-1;i++){s->a[i] = s->a[i+1];}s->size--;
}//尾删
void PopBack(SL* s)
{assert(s);assert(s->size);s->size--;
}//任意位置的插入
void Insert(SL* s, int pos, SLDataType x)
{assert(pos >= 0 && pos <= s->size);check(s);for (int i = s->size; i > pos; i--){s->a[i] = s->a[i - 1];}s->a[pos] = x;s->size++;
}//任意位置的删除,pos是下标
void Erase(SL* s, int pos)
{assert(s);assert(pos >= 0 && pos < s->size);for (int i = pos; i < s->size; i++){s->a[i] = s->a[i + 1];}s->size--;
}//查找元素是否存在,存在返回下标,否则返回-1
int Find(SL* s, SLDataType x)
{assert(s);for (int i = 0; i < s->size; i++){if (x == s->a[i])return i;}return -1;
}

2.4顺序表的打印

//打印
void print(SL* s)
{for (int i = 0; i < s->size; i++){printf("%d ", s->a[i]);}printf("\n");
}

三、顺序表的源代码

//order_table.h#pragma once#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<assert.h>typedef int SLDataType;
//顺序表结构体
typedef struct SL
{SLDataType* a;int size;int capacity;
}SL;//初始化顺序表
void init(SL *s);
//打印
void print(SL* s);//增删查改
void PushFront(SL* s,SLDataType x);//头插void PushBack(SL* s, SLDataType x);//尾插void PopFront(SL* s);//头删void PopBack(SL* s);//尾删void Insert(SL* s, int pos, SLDataType x);//任意位置的插入,pos意为下标void Erase(SL* s, int pos);//任意位置的删除,pos意为下标int Find(SL* s, SLDataType x);//查找元素是否存在,存在返回下标,否则返回-1void SLDestory(SL* s);
//order_table.c
#include"order_table.h"//顺序表结构体
void init(SL* s)
{s->a = NULL;s->size = 0;s->capacity = 0;
}//打印
void print(SL* s)
{for (int i = 0; i < s->size; i++){printf("%d ", s->a[i]);}printf("\n");
}//检查是否满了
void check(SL* s)
{if (s->size == s->capacity){int new_capacity = (s->capacity == 0) ? 4 : s->capacity * 2;SLDataType* temp = (SLDataType*)realloc(s->a, sizeof(SLDataType) * new_capacity);if (temp == NULL){perror("realloc is fail!");exit (EXIT_FAILURE);}s->a = temp;s->capacity =new_capacity;}
}
//头插
void PushFront(SL* s, SLDataType x)
{check(s);for (int i =s->size;i>0;i-- ){s->a[i] =s->a[i-1];}s->a[0] = x;s->size++;
}void PushBack(SL* s, SLDataType x)//尾插
{check(s);s->a[s->size] = x;s->size++;
}void PopFront(SL* s)//头删
{assert(s && s->size);for (int i =0;i<s->size-1;i++){s->a[i] = s->a[i+1];}s->size--;
}void PopBack(SL* s)//尾删
{assert(s);assert(s->size);s->size--;
}void Insert(SL* s, int pos, SLDataType x)//任意位置的插入
{assert(pos >= 0 && pos <= s->size);check(s);for (int i = s->size; i > pos; i--){s->a[i] = s->a[i - 1];}s->a[pos] = x;s->size++;
}void Erase(SL* s, int pos)//任意位置的删除
{assert(s);assert(pos >= 0 && pos < s->size);for (int i = pos; i < s->size; i++){s->a[i] = s->a[i + 1];}s->size--;
}int Find(SL* s, SLDataType x)//查找元素是否存在,存在返回下标,否则返回-1
{assert(s);for (int i = 0; i < s->size; i++){if (x == s->a[i])return i;}return -1;
}void SLDestory(SL* s)
{assert(s);if(s->a){free(s->a);}s->a = NULL;s->size = s->capacity = 0;
} 

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

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

相关文章

GEE计算遥感生态指数RSEI

目录 RESI湿度绿度热度干度源代码归一化函数代码解释整体的代码功能解释:导出RSEI计算结果参考文献RESI RSEI = f (Greenness,Wetness,Heat,Dryness)其遥感定义为: RSEI = f (VI,Wet,LST,SI)式中:Greenness 为绿度;Wetness 为湿度;Thermal为热度;Dryness 为干度;VI 为植被指数…

【多媒体】Java实现MP4和MP3音视频播放器【JavaFX】【音视频播放】

在Java中播放音视频可以使用多种方案&#xff0c;最常见的是通过Swing组件JFrame和JLabel来嵌入JMF(Java Media Framework)或Xuggler。不过&#xff0c;JMF已经不再被推荐使用&#xff0c;而Xuggler是基于DirectX的&#xff0c;不适用于跨平台。而且上述方案都需要使用第三方库…

拒绝信息差!一篇文章说清Stable Diffusion 3到底值不值得冲

前言 就在几天前&#xff0c;Stability AI正式开源了Stable Diffusion 3 Medium&#xff08;以下简称SD3M&#xff09;模型和适配CLIP文件。这家身处风雨飘摇中的公司&#xff0c;在最近的一年里一直处于破产边缘&#xff0c;就连创始人兼CEO也顶不住压力提桶跑路。 即便这样&…

[leetcode]minimum-absolute-difference-in-bst 二叉搜索树的最小绝对差

. - 力扣&#xff08;LeetCode&#xff09; /*** Definition for a binary tree node.* struct TreeNode {* int val;* TreeNode *left;* TreeNode *right;* TreeNode() : val(0), left(nullptr), right(nullptr) {}* TreeNode(int x) : val(x), left(null…

java如何在字符串中间插入字符串

java在字符串中插入字符串&#xff0c;需要用到insert语句 语法格式为 sbf.insert(offset,str) 其中,sbf是任意字符串 offset是插入的索引 str是插入的字符串 public class Insert {public static void main(String[] args) {// 将字符串插入到指定索引StringBuffer sbfn…

FFmpeg5.0源码阅读——格式检测

摘要&#xff1a;在拿到一个新的格式后&#xff0c;FFmpeg总是能够足够正确的判断格式的内容并进行相应的处理。本文在描述FFmpeg如何进行格式检测来确认正在处理的媒体格式类型&#xff0c;并进行相应的处理。   关键字&#xff1a;FFmpeg,format,probe 在调用FFmpeg的APIav…

变量的定义和使用

1.定义 变量&#xff0c;就是用来表示数据的名字 Python 中定义变量非常简单&#xff0c;只需将数据通过等号()赋值给一个符合命名规范的标识符即可 name"Camille" name 123 变量的使用 变量的使用是指在程序中引用一个已经定义的变量。 例如&#xff0c;如果…

LeetCode 196, 73, 105

目录 196. 删除重复的电子邮箱题目链接表要求知识点思路代码 73. 矩阵置零题目链接标签简单版思路代码 优化版思路代码 105. 从前序与中序遍历序列构造二叉树题目链接标签思路代码 196. 删除重复的电子邮箱 题目链接 196. 删除重复的电子邮箱 表 表Person的字段为id和email…

昇思MindSpore学习总结七——模型训练

1、模型训练 模型训练一般分为四个步骤&#xff1a; 构建数据集。定义神经网络模型。定义超参、损失函数及优化器。输入数据集进行训练与评估。 现在我们有了数据集和模型后&#xff0c;可以进行模型的训练与评估。 2、构建数据集 首先从数据集 Dataset加载代码&#xff0…

检测站机动车授权签字人试题附答案

16、___的轮胎胎冠上花纹深度不得小于3.2mm。( ) A、乘用车 B、摩托车 C、货车的转向轮&#xff08;正确答案&#xff09; D、挂车 17、最大设计时速≥100km/h的机动车其转向盘自由转动量不大于__。( ) A、30 度 B、20 度&#xff08;正确答案&#xff09; C、45 度 D、40度…

在windows上安装objection

安装命令pip install objection -i https://mirrors.aliyun.com/pypi/simple hook指定进程 objection -g 测试 explore 进程名不定是包名&#xff0c;也可能是app名字&#xff0c;如“测试”就是app的名字 若出现如下错误&#xff0c;说明python 缺少setuptools 直接安装setu…

掷骰子游戏 、 求绝对值,平方根,对数,正弦值 题目

题目 JAVA33 掷骰子游戏分析&#xff1a;代码&#xff1a; JAVA34 求绝对值&#xff0c;平方根&#xff0c;对数&#xff0c;正弦值分析&#xff1a;代码&#xff1a; JAVA33 掷骰子游戏 描述开发一个掷骰子游戏&#xff0c;即每次运行程序时&#xff0c;产生一个[1,6]之间的随…

秋招突击——设计模式补充——单例模式、依赖倒转原则、工厂方法模式

文章目录 引言正文依赖倒转原则工厂方法模式工厂模式的实现简单工厂和工厂方法的对比 抽线工厂模式最基本的数据访问程序使用工厂模式实现数据库的访问使用抽象工厂模式的数据访问程序抽象工厂模式的优点和缺点使用反射抽象工厂的数据访问程序使用反射配置文件实现数据访问程序…

检索增强生成RAG系列6--RAG提升之查询结构化(Query Construction)

系列5中讲到会讲解3个方面RAG的提升&#xff0c;它们可能与RAG的准确率有关系&#xff0c;但是更多的它们是有其它用途。本期来讲解第二部分&#xff1a;查询结构化&#xff08;Query Construction&#xff09;。在系列3文档处理中&#xff0c;我们着重讲解了文档解析&#xff…

C++ dll导出类的方法

要在C动态库中导出类&#xff0c;可以使用以下步骤&#xff1a; 定义一个类并实现其成员函数。在类的声明前加上__declspec(dllexport)标记&#xff08;Windows平台&#xff09;或__attribute__((visibility("default")))标记&#xff08;Linux平台&#xff09;&…

C语言学习笔记--第一个程序

第一个C语言程序 #include<stdio.h> //引用输入输出头文件&#xff0c;每一次都需要引用这个文件 //.h是头文件 // .c是源文件 // .cpp是C源文件&#xff0c;兼容C //C的第一个程序 // 行注释&#xff08;只能注释这一行&#xff09; /*块注释 */ int main() {printf(&…

能保存到相册的风景视频在哪下载?下载风景视频网站分享

在当今以视觉为核心的时代&#xff0c;高清美丽的风景视频不仅能够丰富我们的日常生活&#xff0c;还能提供心灵上的慰藉。无论是为了制作视频项目&#xff0c;还是仅仅想要珍藏一些精美的风景画面&#xff0c;获取高质量的风景视频素材显得尤为重要。许多人可能会问&#xff1…

PTrade量化软件常见问题整理系列2

一、研究界面使用get_fundamentals函数报错&#xff1a;error_info:获取token失败&#xff1f; 研究界面使用get_fundamentals函数报错&#xff1a;error_info:获取token失败&#xff1f; 1、测试版本202202.01.052&#xff0c;升级202202.01.051版本后&#xff0c;为了解决不…

在虚拟仿真中学习人工智能,可以达到什么目标?

人工智能已经成为引领社会创新的关键力量&#xff0c;想要在这个充满机遇的领域中脱颖而出&#xff0c;掌握扎实的专业技能和积累丰富的实践经验至关重要。然而&#xff0c;许多学习者在追求这一目标的过程中面临着几个主要问题&#xff1a;专业技术掌握有难度、实践经验积累存…

linux中awk,sed, grep使用

《linux私房菜》这本书中将sed和awk一同归为行的修改这一点&#xff0c;虽然对&#xff0c;但不利于实际处理问题时的思考。因为这样的话&#xff0c;当我们实际处理问题时&#xff0c;遇到比如说统计文本打印内容时&#xff0c;我们选择sed还是awk进行处理呢&#xff1f; 也因…