84.【C语言】数据结构之顺序表的头部插入和删除

目录

3.操作顺序表

1.分析头部插入函数

SeqList.c写入

容量检查函数

注意

main.c改为

SeqList.h添加SLPushFront的声明

运行结果

2.分析头部删除函数

SLPopFront代码

main.c改为

SeqList.h添加SLPopFront的声明

图分析

运行结果


承接83.【C语言】数据结构之顺序表的尾部插入和删除文章

3.操作顺序表

1.分析头部插入函数

SeqList.c写入

cpp 复制代码
void SLPushFront(SL* ps,SLDataType x)
{
	assert(ps);
	SLCheckCapacity(ps);
	int end = ps->size-1;//定义尾部,一开始a[end-1]指向最后一个元素
	while (end >= 0)//注意循环条件
	{
		ps->a[end + 1] = ps->a[end];
		end--;
	}
	ps->a[0] = x;
	ps->size++;
}

容量检查函数

cpp 复制代码
void SLCheckCapacity(SL* ps)
{
	assert(ps);
	if (ps->size == ps->capacity)
	{
		SLDataType* tmp = (SLDataType*)realloc(ps->a, sizeof(SLDataType) * ps->capacity * 2);
		if (tmp == NULL)
		{
			perror("realloc");
			return;//错误返回
		}
		ps->capacity *= 2;
		ps->a = tmp;
	}
}

注意

头插时,元素会逐个向后移动,因此要先进行容量检查,再移动元素,最后不要忘记为有效元素个数size+1;

main.c改为

cpp 复制代码
#include "SeqList.h"
//定义测试顺序表的函数
void TestSeqList1()
{
	SL s;
	SLInit(&s);
	SLPushBack(&s, 1);
	SLPushBack(&s, 2);
	SLPushBack(&s, 3);
	SLPushBack(&s, 4);
	SLPrint(&s);
	SLPushFront(&s, 1);
	SLPrint(&s);
	SLDestory(&s);
}

int main()
{
	TestSeqList1();
	return 0;
}

SeqList.h添加SLPushFront的声明

运行结果

头插N个元素的时间复杂度为,运行效率不高,尽量避免头插,使用尾插(尾插N个元素的时间复杂度为)

2.分析头部删除函数

SLPopFront代码

cpp 复制代码
void SLPopFront(SL * ps)
{
	assert(ps);
	assert(ps->size);
	int begin = 1;
	while (begin < ps->size)
	{
		ps->a[begin - 1] = ps->a[begin];
		begin++;
	}
	ps->size--;
}

注:ps->size可能为负数,因此要断言ps->size的正负

main.c改为

cpp 复制代码
void TestSeqList1()
{
	SL s;
	SLInit(&s);
	SLPushBack(&s, 1);
	SLPushBack(&s, 2);
	SLPushBack(&s, 3);
	SLPushBack(&s, 4);
	SLPushBack(&s, 5);
	SLPrint(&s);
	SLPopFront(&s);
	SLPrint(&s);
	SLDestory(&s);
}

SeqList.h添加SLPopFront的声明

图分析

运行结果

相关推荐
xieliyu.15 分钟前
Java手搓数据结构:从零模拟实现无头双向非循环链表
java·数据结构·链表
csbysj202015 分钟前
Java 条件语句
开发语言
Ulyanov1 小时前
《现代 Python 桌面应用架构实战:PySide6 + QML 从入门到工程化》 开发环境搭建与工具链极简主义 —— 拒绝臃肿,构建工业级基座
开发语言·python·qt·ui·架构·系统仿真
逻辑驱动的ken1 小时前
Java高频面试场景题19
java·开发语言·面试·职场和发展·求职招聘
初心未改HD1 小时前
Go语言net/http与Web开发:构建高性能HTTP服务
开发语言·golang
如何原谅奋力过但无声1 小时前
【灵神高频面试题合集01-03】相向双指针、滑动窗口
数据结构·python·算法·leetcode
叼烟扛炮2 小时前
C++第一讲:C++ 入门基础
开发语言·c++·函数重载·引用·内联函数·nullptr
Ulyanov2 小时前
《现代 Python 桌面应用架构实战:PySide6 + QML 从入门到工程化》:QML 声明式语法与霓虹按钮 —— 当 Python 遇见现代美学
开发语言·python·ui·qml·系统仿真·雷达电子对抗仿真
弹不出的5h3ll2 小时前
Ghost Bits:高位截断如何让 Java WAF 形同虚设
java·开发语言
码界筑梦坊2 小时前
113-基于Python的国际超市电商销售数据可视化分析系统
开发语言·python·信息可视化·毕业设计·fastapi