【数据结构】顺序表——赋源码(结尾)

news2025/1/11 20:01:38

目录

1. 线性表

2. 顺序表

2.1 概念与结构

2.2 分类

2.2.1 静态顺序表

2.2.2 动态顺序表

2.3 动态顺序表的实现


正文

1. 线性表

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

2. 顺序表

2.1 概念与结构

概念:顺序表是⽤⼀段物理地址连续的存储单元依次存储数据元素的线性结构,⼀般情况下采⽤数组存储。

顺序表和数组的区别?
顺序表的底层结构是数组,对数组的封装,实现了常⽤的增删改查等接⼝

2.2 分类

2.2.1 静态顺序表

静态顺序表缺陷:空间给少了不够⽤,给多了造成空间浪费

2.2.2 动态顺序表

2.3 动态顺序表的实现

先创建三个文件

如图:

在头文件(SeqList.h)中引入相应的头文件

在相应的源文件中引入头文件

第一步进行初始化和销毁代码的实现

在头文件中定义函数

在源文件中写函数方法

在测试文件中调用此方法,并调试

下面该插入数据 

SeqList.h

在插入数据之前我们药判断顺序表中的空间是否充足  所以我们要写一个判断空间是否充足的函数

SeqList.h

SeqList.c

接下来是删除数据

SeqList.h

SeqList.c

接下来是在指定位置的插入数据/删除数据

先要找到指定位置才可之后的操作

SeqList.h

SeqList.c

附源码

SeqList.h

#pragma once
#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
//定义动态顺序表结构
typedef int SLDataType;
typedef struct SeqList
{
	SLDataType* arr;
	int capacity;
	int size;
}SL;
//初始化
void SLInit(SL* s);
//销毁
void SLDestroy(SL* s);
//插入数据
void SLPushBack(SL* s, SLDataType x);
void SLPushFront(SL* s, SLDataType x);
//打印顺序表
void SLPrint(SL* s);
//判断空间是否充足
void SLCheckCapacity(SL* s);
//删除
void SLPopBack(SL* s);
void SLPopFront(SL* s);
//指定位置插入/删除数据
void SLInsert(SL* s, SLDataType x, int pos);
void SLErase(SL* s, int pos);
//查找
int SLFind(SL* s, int pos);

SeqList.c

#define _CRT_SECURE_NO_WARNINGS 1
#include"SeqList.h"
//初始化
void SLInit(SL* s) {
	s->arr = NULL;
	s->capacity = s->size = 0;
}
//销毁
void SLDestroy(SL* s) {
	if (s->arr)//相当于s->arr  != NULL
	{
		free(s->arr);
	}
	s->arr = NULL;
	s->capacity =s->size =  0;
}
//判断空间是否充足
void SLCheckCapacity(SL* s)
{
	//判断空间是否充足
	if (s->capacity == s->size)
	{
		int newCapacity = s->capacity == 0 ? 4 : 2 * s->capacity;
		SLDataType* tmp = (SLDataType*)realloc(s->arr, newCapacity * sizeof(SLDataType));
		if (tmp == NULL)
		{
			perror("realloc");
			exit(1);
		}
		s->arr = tmp;
		s->capacity = newCapacity;
	}

}
//插入数据
//尾插
void SLPushBack(SL* s, SLDataType x) {
	assert(s);//等价于s!=NULL
	SLCheckCapacity(s);
	//空间够的情况
	s->arr[s->size++] = x;
}
//头插
void SLPushFront(SL* s, SLDataType x)
{
	assert(s);
	SLCheckCapacity(s);
	for (int i = s->size; i > 0; i--)
	{
		s->arr[i] = s->arr[i - 1];
	}
	s->arr[0] = x;
	s->size++;
}
//打印顺序表
void SLPrint(SL* s)
{
	for (int i = 0; i < s->size; i++)
	{
		printf("%d ", s->arr[i]);
	}
	printf("\n");
}
//删除
void SLPopBack(SL* s)
{
	assert(s);
	assert(s->size);
	//s->arr[s->size - 1] = -1;
	s->size--;
}
void SLPopFront(SL* s)
{
	assert(s);
	assert(s->size);
	for (int i = 0; i<s->size-1 ; i++)
	{
		s->arr[i] = s->arr[i + 1];
	}
	s->size--;
}

//指定位置插入/删除数据
void SLInsert(SL* s, SLDataType x, int pos)
{
	assert(s);
	assert(pos>=0 && pos<=s->size);
	SLCheckCapacity(s);
	for (int i = s->size; i >pos ; i--)
	{
		s->arr[i] = s->arr[i - 1];
	}
	s->arr[pos] = x;
	s->size++;
}
void SLErase(SL* s, int pos)
{
	assert(s);
	assert(pos >= 0 && pos < s->size);
	for (int i = pos; i < s->size; i++)
	{
		s->arr[i] = s->arr[i + 1];
	}
	s->size--;
}
//查找
int SLFind(SL* s, int pos)
{
	assert(s);
	for (size_t i = 0; i < s->size; i++)
	{
		if (s->arr[i] == pos)
			return 1;
	}
	return -1;
}

test.c

#define _CRT_SECURE_NO_WARNINGS 1
#include"SeqList.h"
void test01()
{
	SL s;
	SLInit(&s);
	//SLPushBack(&s, 1);
	//SLPushBack(&s, 2);
	//SLPushBack(&s, 3);
	//SLPushBack(&s, 4);
	//SLPushFront(&s, 1);
	//SLPushFront(&s, 2);
	//SLPushFront(&s, 3);
	//SLPushFront(&s, 4);
	//SLInsert(&s, 5, 2);
	//SLInsert(&s, 5, 0);
	//SLInsert(&s, 5, 6);
	//SLPopBack(&s);
	/*SLPopFront(&s);
	SLPrint(&s);
	SLPopFront(&s);
	SLPrint(&s);
	SLPopFront(&s);
	SLPrint(&s);
	SLPopFront(&s);
	SLPrint(&s);
	SLPrint(&s);*/
	SLDestroy(&s);
};
int main()
{
	test01();
	return 0;
}


以上就是顺序表的实现代码 如有问题欢迎留言!

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

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

相关文章

停止项目大小调整,开始搜索层自动缩放!

作者&#xff1a;来自 Elastic Matteo Piergiovanni&#xff0c;John Verwolf 我们新的 serverless 产品的一个关键方面是允许用户部署和使用 Elastic&#xff0c;而无需管理底层项目节点。为了实现这一点&#xff0c;我们开发了搜索层自动扩展&#xff0c;这是一种根据我们将在…

华为路由的AAA是什么?

1.AAA及用户管理概述 华为路由的AAA是Authentication(认证)、‌Authorization(授权)和Accounting(计费)的简称&#xff0c;‌是一种提供认证、‌授权和计费的安全管理机制。‌ AAA作为一种网络安全管理机制&#xff0c;‌主要提供以下功能和服务&#xff1a;‌ 认证&#xff…

Linux系统编程:线程 1

1.线程的概念 线程——轻量级的进程&#xff0c;线程是CPU执行的最小单位&#xff0c;进程是资源分配的基本单位&#xff0c;线程的创建和调度的时空开销都比进程小&#xff1b; 2.线程的组成 线程组成&#xff1a;线程pid&#xff0c;程序计数器&#xff0c;寄存器集合&…

pdf文件密码忘记,有办法可以打开pdf文件吗?

为确保PDF文件的重要信息不轻易外泄&#xff0c;我们一般会给pdf文件设置打开密码&#xff0c;确保pdf文件的隐私与安全&#xff0c;但随着时间的推移&#xff0c;让我们遗忘了原本设置的密码&#xff0c;这时我们该怎么办呢&#xff1f; 当大家遇到这种情况时&#xff0c;可能…

箱号/柜号是什么?各种单据处理有没有省力的办法?

集装箱编号&#xff0c;作为全球独一无二的标识符&#xff0c;其结构严谨且信息丰富。该编号由四部分构成&#xff1a;首先是三个字母组成的箱主代码&#xff0c;这代表了集装箱的拥有者&#xff0c;即船公司或租箱公司的专属标识&#xff1b;紧接着是固定字母“U”&#xff0c…

SpringBoot快速入门(自动创建)

目录 前言 步骤 1 创建项目 2 选择生成器springBoot 3 修改后&#xff0c;如图所示 4 点击下一步 5 点击Web----SpringWeb 6 点击创建 6.1 如果发生报错如: 6.2 替换合适版本&#xff0c;等待重新加载 7 添加contronller类 7.1 添加HelloController 类 8 ​​创建…

Linux驱动入门实验班——SR501红外模块驱动(附百问网视频链接)

目录 一、工作方式 二、接口图 三、编写思路 1.构造file_operations结构体 2.实现read函数 3.编写入口函数 4.编写中断处理函数 5.编写出口函数 6.声明出入口函数以及协议 四、源码 五、课程链接 一、工作方式 SR501人体红外感应模块有两种工作模式&#xff1a; …

PMP和软考高项知识的重叠和差异

PMP和高项是项目管理证书&#xff0c;备考了高项之后&#xff0c;也可以参加PMP考试&#xff0c;今天我们就来说一说PMP和高项知识的重叠度以及差异。&#xff08;文末PMP资料&#xff09; 一、知识体系的重叠 1、 项目管理过程 PMP和高项都强调项目管理的全过程&#xff0c;包…

电脑屏幕录制指南,2024四大免费录屏软件推荐!

无论是制作教学视频、录制在线课程、捕捉游戏精彩瞬间&#xff0c;还是进行远程技术支持&#xff0c;一款优秀的录屏软件都是必不可少的工具。今天&#xff0c;我们就来聊聊几款免费且功能强大的录屏软件。 Foxit录屏大师 链接&#xff1a;www.foxitsoftware.cn/REC/ Foxit录…

BGP 反射器联邦实验

要求&#xff1a; 1.如图连接网络&#xff0c;合理规划IP地址&#xff0c;AS 200内IGP协议为OSPF 2.R1属于AS 100&#xff1b;R2-R3-R4小AS 234 R5-R6-R7小AS 567&#xff0c;同时声明大AS 200&#xff0c;R8属于AS 300 3.R2-R5 R4-R7 之间为联邦EBGP邻居关系 4.R1-R8之…

实时捕捉与追溯:得物基于 eBPF 打造云上网络连接异常摄像头

近期我们容器 SRE 团队基于 eBPF 技术建设网络连接异常感知能力&#xff0c;灰度上线过程中发现了生产环境 10 以上的应用配置错误、程序 Bug 等问题。在和应用负责同学同步风险过程中&#xff0c;大家都挺好奇我们如何实现在对应用无侵入的情况下发现服务连接异常的。本篇文档…

贷齐乐hpp+php特性注入

文章目录 运行过程waf第一层waf拦截第二层waf拦截 数据库查询语句注入思路注入 运行过程 foreach ($_REQUEST as $key > $value) {$_REQUEST[$key] dowith_sql($value);}$request_uri explode("?", $_SERVER[REQUEST_URI]);if (isset($request_uri[1])) {$rewr…

77.游戏分析工具计算数据偏移

免责声明&#xff1a;内容仅供学习参考&#xff0c;请合法利用知识&#xff0c;禁止进行违法犯罪活动&#xff01; 内容参考于&#xff1a;易道云信息技术研究院 上一个内容&#xff1a;76.游戏分析工具读取内存存到对象数据分析器一 以它的代码为基础进行修改 COBJContext…

免费领取 | S-SDLC差距分析2024发布会,服务名额先到先得

​2024全新版S-SDLC研发安全能力成熟度模型即将发布&#xff01;可帮助企业进一步引入行业最佳实践&#xff0c;弥补安全开发能力短板&#xff0c;快速提升软件安全开发整体水平。 8月15日&#xff0c;我们将开启直播&#xff0c;正式发布2024全新版S-SDLC研发安全能力成熟度模…

代码随想录算法训练营第十五天

力扣题部分: 110.平衡二叉树 题目链接:. - 力扣&#xff08;LeetCode&#xff09; 题面: 给定一个二叉树&#xff0c;判断它是否是平衡二叉树 平衡二叉树 是指该树所有节点的左右子树的深度相差不超过 1 思路(递归): 还是递归三部曲(关于三部曲的具体内容和对递归看法建议可见昨…

Vulnhub JIS-CTF靶机详解

项目地址 https://www.vulnhub.com/entry/jis-ctf-vulnupload,228/https://www.vulnhub.com/entry/jis-ctf-vulnupload,228/ 修改靶机的网卡 开机时长按shift&#xff0c;进入此页面 选择root模式进入 将只读模式改为读写模式 mount -o remount,rw / 查看本机的网卡名称 …

【数据分享】《青海省统计年鉴》2000-2023

而今天要限时免费分享的数据就是2000-2023年间出版的《青海省统计年鉴》并以多格式提供免费下载。&#xff08;无需分享朋友圈即可获取&#xff09; 数据介绍 青海省&#xff0c;位于中国西北部&#xff0c;青藏高原的东北部&#xff0c;是一个资源丰富、民族众多的地区。…

利用WebSocket实现来单提醒和用户催单

文章目录 概要整体架构流程技术细节小结 概要 来单提醒&#xff1a; 业务场景&#xff1a;在电商平台、外卖平台等应用场景中&#xff0c;当有新的订单产生时&#xff0c;系统需要及时通知相关人员处理新订单。 目的&#xff1a;确保订单能够得到快速响应&#xff0c;提高客户…

XSS盲打与cookie劫持

目录 【学习目标、重难点知识】 【学习目标】 【重难点知识】 XSS盲打&#xff08;加载远程攻击payload&#xff09; XSS偷cookie cookie收集 在线XSS收集平台的使用 1. BeeF框架的使用 BeeF简介 安装和使用 XSS 一些实战应用 1. XSS PDF 2. 公网投毒 3. 网站挂马…

WUP-CH34X ch34x系列芯片USB转串口通信uniapp插件使用说明

插件地址&#xff1a;WUP-CH34X 系列芯片USB转串口通信安卓库 简介 本文档是针对 CH340/CH341/CH342/CH343/CH344/CH347/CH9101/CH9102/CH9103/CH9104/CH9143的 USB 转串口安卓库的开发说明文档。 主要介绍如何使用芯片的 USB 转异步串口功能&#xff08;以下简称 CH34XUART…