【数据结构】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…

LeetCode 196, 73, 105

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

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

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

在windows上安装objection

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

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

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

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

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

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

在当今以视觉为核心的时代&#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; 也因…

​香橙派AIpro测评:usb鱼眼摄像头的Camera图像获取

一、前言 近期收到了一块受到业界人士关注的开发板"香橙派AIpro",因为这块板子具有极高的性价比&#xff0c;同时还可以兼容ubuntu、安卓等多种操作系统&#xff0c;今天博主便要在一块832g的香橙派AI香橙派AIpro进行YoloV5s算法的部署并使用一个外接的鱼眼USB摄像头…

React 中如何使用 Monaco

Monaco 是微软开源的一个编辑器&#xff0c;VSCode 也是基于 Monaco 进行开发的。如果在 React 中如何使用 Monaco&#xff0c;本文将介绍如何在 React 中引入 Monaco。 安装 React 依赖 yarn add react-app-rewired --dev yarn add monaco-editor-webpack-plugin --dev yarn…

学习和发展人工智能:新兴趋势和成功秘诀

人工智能(AI)继续吸引组织&#xff0c;因为它似乎无穷无尽地提高生产力和业务成果。在本博客中&#xff0c;了解学习和发展(L&D)部门如何利用人工智能改进流程&#xff0c;简化工作流程&#xff1f; 学习与发展(L&D)部门领导开始探索如何提高和支持人工智能能力的劳动…

1-认识网络爬虫

1.什么是网络爬虫 ​ 网络爬虫&#xff08;Web Crawler&#xff09;又称网络蜘蛛、网络机器人&#xff0c;它是一种按照一定规则&#xff0c;自动浏览万维网的程序或脚本。通俗地讲&#xff0c;网络爬虫就是一个模拟真人浏览万维网行为的程序&#xff0c;这个程序可以代替真人…

工业智能网关在现代工业生产中的重要性-天拓四方

工业智能网关是一款具备挖掘工业设备数据并接入到自主开发的云平台的智能嵌入式网络设备。它具备数据采集、协议解析、边缘计算&#xff0c;以及4G/5G/WiFi数据传输等功能&#xff0c;并能接入工业云平台。这种网关不仅支持采集PLC、传感器、仪器仪表和各种控制器&#xff0c;还…

iss文件本机可以访问,其他电脑无法访问解决

1.搜索的时候有很多答案&#xff0c;总结就是2种 引用来自这位大佬的博客跳转 2.我实际解决了的方法 将这里的ip地址修改为你局域网wifi的ip 如何看自己wifi的ip&#xff0c;大家自行百度&#xff01;

linux中与网络有关的命令

本文的命令总览 ifconfig命令 在 Linux 系统中&#xff0c;ifconfig 命令用于配置和显示网络接口的信息&#xff0c;包括 IP 地址、MAC 地址、网络状态等。同时我们也可以利用ifconfig 命令设置网络接口对应的ip地址&#xff0c;子网掩码等 当你使用 ifconfig 命令时&#xf…