初识顺序表---C语言

目录

一、什么是顺序表

二、顺序表的分类

顺序表分为静态顺序表和动态顺序表

三、动态顺序表的实现

实现最基本的增删查改功能

(1)增

(2)删

(3)查

(4)改

(5)最后不要忘记销毁创建的空间


一、什么是顺序表

顺序表是一种以数组为基础的结构,对数组进行封装,实现常用的增删改查等操作的。

二、顺序表的分类

顺序表分为静态顺序表和动态顺序表

(1)静态顺序表:使用定长数组来存储元素

复制代码
//静态顺序表
#define N 10

typedef int SLDateType;
typedef struct SeqList
{
	SLDateType arr[N];
	int size;//有效元素个数
}SL;

使用宏来定义一个常量,作为数组的长度

结构体中包括两个部分:定长数组和记录数组中有效元素个数的变量

缺点:空间是定死的,给多了浪费,给少了不够用

(2)动态顺序表:按需申请空间,减少空间浪费

复制代码
//动态顺序表
typedef int SLDateType;

typedef struct SeqList
{
	SLDateType* arr;
	int capacity;//当前内存大小
	int size;//有效元素个数
}SL;

结构体中包含三个部分:分别是数组指针、当前数组的大小、有效元素个数

三、动态顺序表的实现

实现最基本的增删查改功能
(1)增
复制代码
//将判断空间是否足够封装为一个函数
void SLCheckCapcity(SL * ps)
{
	if (ps->capcity == ps->size)
	{
		//判断capcity是否为0
		int newcapcity = ps->capcity == 0 ? 4 : 2 * ps->capcity;
		//使用realloc进行扩容
		SLtypeDate* tmp = (SLtypeDate*)realloc(ps->arr, newcapcity * sizeof(SLtypeDate));
		//由于realloc是有可能不成功的,所以要进行判断,并且不能直接赋值给结构体,避免原数据丢失
		if (tmp == NULL)
		{
			perror("realloc");
			exit(1);
		}
		ps->arr = tmp;
		ps->capcity = newcapcity;
	}
}
void SLPushBack(SL*ps, SLtypeDate x)
{
	assert(ps);
	//插入数据要先判断内存够不够 相等则说明内存不够
	SLCheckCapcity(ps);
	ps->arr[ps->size++] = x;
}
//头插
void SLPushFront(SL* ps, SLtypeDate x)
{
	assert(ps);
	SLCheckCapcity(ps);
	for (int i = ps->size; i > 0; i--)
	{
		ps->arr[i] = ps->arr[i - 1];
	}
	ps->arr[0] = x;
	ps->size++;
}
//在指定位置之前插入数据
void SLInsert(SL* ps, int pos, SLtypeDate x)
{
	assert(ps);
	//因为是之前所以可以等于
	assert(pos >= 0 && pos <= ps->size);
	SLCheckCapcity(ps);
	for (int i = ps->size; i > pos; i--)
	{
		ps->arr[i] = ps->arr[i - 1];
	}
	ps->arr[pos] = x;
	ps->size++;
}
(2)删
复制代码
//删除->尾删
void SLPopBack(SL* ps)
{
	assert(ps);
	assert(ps->size);
	ps->size--;
}
//删除->头删
void SLPopFront(SL* ps)
{
	assert(ps);
	assert(ps->size);
	for (int i = 0; i < ps->size-1; i++)
	{
		ps->arr[i] = ps->arr[i + 1];
	}
	ps->size--;
}
//指定位置删除
void SLErase(SL* ps, int pos)
{
	assert(ps);
	assert(pos >= 0 && pos < ps->size);
	assert(ps->size);
	for (int i = pos; i < ps->size; i++)
	{
		ps->arr[i] = ps->arr[i + 1];
	}
	ps->size--;
}
(3)查
复制代码
int SLFind(SL* ps, SLtypeDate x)
{
	int i = 0;
	int flag = -1;
	for(i = 0;i<ps->size;i++)
	{
		if (ps->arr[i] == x)
		{
			return i;
		}
	}
	return flag;
}
(4)改
复制代码
//修改
void SLModify(SL* ps, int pos, SLtypeDate x)
{
	assert(ps);
	assert(pos >= 0 && pos < ps->size);
	ps->arr[pos] = x;
}
(5)最后不要忘记销毁创建的空间
复制代码
//销毁
void SLDestory(SL* ps)
{
	if (ps->arr)
	{
		free(ps->arr);
	}
	ps->size = 0;
	ps->capcity = 0;
}
相关推荐
贩卖黄昏的熊1 小时前
数据结构示例代码
数据结构
_fairyland2 小时前
数据结构 力扣 练习
数据结构·考研·算法·leetcode
速易达网络3 小时前
C语言常见推理题
java·c语言·算法
沪漂的码农3 小时前
C语言队列与链表结合应用完整指南
c语言·链表
点云SLAM4 小时前
算法与数据结构之二叉树(Binary Tree)
数据结构·算法·二叉树·深度优先·广度优先·宽度优先
小龙报4 小时前
《算法通关指南:算法基础篇 --- 一维前缀和 — 1. 【模板】一维前缀和,2.最大子段和》
c语言·数据结构·c++·算法·职场和发展·创业创新·visual studio
R6bandito_4 小时前
STM32 HAL库原子操作编译问题解决指南
c语言·ide·经验分享·stm32·单片机·嵌入式硬件·mcu
树在风中摇曳5 小时前
LeetCode 1658 | 将 x 减到 0 的最小操作数(C语言滑动窗口解法)
c语言·算法·leetcode
degen_5 小时前
BDS 执行平台相关动作
c语言·笔记·bios
.柒宇.6 小时前
力扣hoT100之找到字符串中所有字母异位词(java版)
java·数据结构·算法·leetcode