【数据结构】超详细之顺序表(利用C语言实现)

news2024/12/24 8:47:07

文章目录

  • 前言
  • 一、顺序表是什么?
  • 二、顺序表的实现步骤
    • 1.顺序表的初始化以及开辟空间
    • 2.实现顺序表的头插、尾插以及打印
    • 3.实现顺序表的头删、尾删以及打印
    • 4.实现顺序表的查找
    • 5.实现顺序表指定位置插入
    • 6.实现顺序表指定位置删除
    • 7.释放内存
  • 总结


前言

数据结构是一个程序员必须会的一种操作功能,学习数据结构能提高我们的逻辑思维能力以及解决实际项目能力,数据结构分为很多种,今天我们要讲的是数据结构中的顺序表.

一、顺序表是什么?

1.顺序表其本质是一种类似于数组的空间,其存储方式与数组一样,具有一段连续的空间.

2.顺序表的功能大致为实现增删改查操作,像QQ群或者微信群中存放的群员列表,都可以用顺序表实现.

3.在实际应用中,顺序表能大大提高工作效率,是一种结构化、具体化的工具

二、使用步骤

1.顺序表的初始化以及开辟空间

代码如下(示例):
 

//.h文件内
#pragma once
#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
typedef int TYPE;//将类型重命名作为存放数据的类型,使程序灵活改变

//定义一个结构体类型,用于存放数据
typedef struct  SequenceList
{
    TYPE* Data;//数据
    int sz;//计算有效数据
    int sum;//计算空间容量
}SL;

//初始化顺序表
void SeqListInit(SL* ps);
//.c文件内
#define _CRT_SECURE_NO_WARNINGS 1
#include"SequenceList.h"

//初始化顺序表
void SeqListInit(SL* ps)
{
	assert(ps);
	ps->Data = (TYPE*)malloc(sizeof(TYPE)*4);//开辟四个空间
	if (ps->Data == NULL)
	{
		perror("malloc");
		return;
	}
	ps->sum = 4;
	ps->sz = 0;
}

2.实现顺序表的头插、尾插以及打印

代码如下(示例):

.h文件
//顺序表头部插入(头插)
void SeqListPushFront(SL* ps, TYPE x);
//顺序表尾部插入(尾插)
void SeqListPushBack(SL* ps, TYPE x);
//打印数据
void SeqListPrint(SL* ps);
.c文件
//扩容
void SLCheckCapacity(SL* ps)
{
	assert(ps);
	if (ps->sum == ps->sz)
	{
		TYPE* Add = (TYPE*)realloc(ps->Data, sizeof(TYPE) * 8);//默认一次扩增加4空间
		if (Add == NULL)
		{
			perror("realloc");
			return;
		}
		ps->Data = Add;
		ps->sum += 4;
	}
}
//顺序表头部插入(头插)
void SeqListPushFront(SL* ps, TYPE x)
{
	assert(ps);
	//判断是否还有容量,是否需要扩容
	SLCheckCapacity(ps);
	int n = ps->sz;
	while (n>0)
	{
		ps->Data[n] = ps->Data[n - 1];
		n--;
	}
	ps->Data[0] = x;
	ps->sum--;
	ps->sz++;
}

//顺序表尾部插入(尾插)
void SeqListPushBack(SL* ps, TYPE x)
{
	assert(ps);
	//判断是否还有容量,是否需要扩容
	SLCheckCapacity(ps);
	ps->Data[ps->sz] = x;
	ps->sum--;
	ps->sz++;
}

//打印数据
void SeqListPrint(SL* ps)
{
	assert(ps);
	int i = 0;
	for (i = 0; i < ps->sz; i++)
	{
		printf("%d->", ps->Data[i]);
	}
}
//.c文件(启动文件)
#define _CRT_SECURE_NO_WARNINGS 1
#include"SequenceList.h"
int main()
{
	SL pr;
	SeqListInit(&pr); //初始化
	SeqListPushBack(&pr, 1);//尾插
	SeqListPushFront(&pr, 2);//头插
	SeqListPushBack(&pr, 3);//尾插
	SeqListPrint(&pr);//打印
	return 0;
}

3.实现顺序表的头删、尾删以及打印

代码如下(示例):

.h文件
//顺序表头部删除(头删)
void SeqListPopFront(SL* ps);
//顺序表尾部删除(尾删)
void SeqListPopBack(SL* ps);
.c文件
//顺序表头部删除(头删)
void SeqListPopFront(SL* ps)
{
	assert(ps);
	if (ps->sz == 0)
	{
		return;
	}
	int n = 0;
	while (n<(ps->sz)-1)
	{
		ps->Data[n] = ps->Data[n + 1];
		n++;
	}
	ps->sum++;
	ps->sz--;
}
//顺序表尾部删除(尾删)
void SeqListPopBack(SL* ps)
{
	assert(ps);
	if (ps->sz == 0)
	{
		return;
	}
	ps->sz--;
}


4.实现顺序表的查找

代码如下(示例):

.h文件
//顺序表的查找
//找到了返回该数下标
//没找到返回-1;
int SeqListFind(SL* ps, TYPE x);
.c文件
//顺序表的查找
//找到了返回该数下标
//没找到返回-1;
int SeqListFind(SL* ps, TYPE x)
{
	assert(ps);
	assert(ps->sz);
	int i = 0;
	for (i = 0; i < ps->sz; i++)
	{
		if (ps->Data[i] == x)
		{
			return i;
		}
	}
	return -1;
}


5.实现顺序表指定位置插入

代码如下(示例):

.h文件
//顺序表指定插入
void SeqListInsert(SL* ps, int pos, TYPE x);
.c文件
//顺序表指定插入
void SeqListInsert(SL* ps, int pos, TYPE x)
{
	assert(ps);
	//判断是否还有容量,是否需要扩容
	SLCheckCapacity(ps);
	assert(pos >= 0 && pos <= ps->sz);
	int n = ps->sz;
	while (n>pos)
	{
		ps->Data[n] = ps->Data[n - 1];
		n--;
	}
	ps->Data[pos] = x;
	ps->sz++;
	ps->sum--;
}

当有指定位置插入功能时,头插和尾插就可以简化成如下代码:

//顺序表头部插入(头插)
void SeqListPushFront(SL* ps, TYPE x)
{
	assert(ps);
	//判断是否还有容量,是否需要扩容
	SLCheckCapacity(ps);
	SeqListInsert(ps, 0, x);
}


//顺序表尾部插入(尾插)
void SeqListPushBack(SL* ps, TYPE x)
{
	assert(ps);
	//判断是否还有容量,是否需要扩容
	SLCheckCapacity(ps);
	SeqListInsert(ps, ps->sz, x);
}

6.实现顺序表指定位置删除

代码如下(示例):

.h文件
//顺序表指定删除
void SeqListErase(SL* ps, int pos);
.c文件
//顺序表指定删除(根据下标进行删除)
void SeqListErase(SL* ps, int pos)
{
	assert(ps);
	assert(pos >= 0 && pos<=ps->sz);
	assert(ps->sz);
	int n = pos + 1;
	while(n<ps->sz)
	{
		ps->Data[n-1] = ps->Data[n];
		n++;
		pos++;
	}
	ps->sz--;
	ps->sum++;
}


7.释放内存

代码如下(示例):

.h文件
//释放空间
void SeqListDestroy(SL* ps);

.c文件

//释放空间
void SeqListDestroy(SL* ps)
{
	assert(ps);
	free(ps->Data);
	ps->Data = NULL;
	ps->sum = 0;
	ps->sz = 0;
}

总结

以上就是我对数据结构——顺序表的理解,谢谢大家观看!

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

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

相关文章

离散数学_九章:关系(3)

9.3 关系的表示 1、用集合表示关系2、用矩阵表示关系矩阵表示关系⭐集合上的关系矩阵 R 自反时 R 对称时 R 反对称时 ⭐确定关系合成的矩阵 3、用有向图表示关系有向图⭐从有向图中 确定关系具有的属性 自反性对称性反对称性传递性 本节及本章的剩余部分研究的所有关系均为二…

函数(详解)——C语言

Hello&#xff0c;友友们前段时间忙拖更了这么久&#xff0c;趁着五一假期好好卷上一波哈哈哈。好的&#xff0c;我们本期主要对C语言中的函数进行讲解。 1.什么是函数 在数学中也常常用到函数&#xff0c;但你对C语言中的函数有了解吗&#xff1f; 在C语言中函数是一段可重…

数据结构学习分享之单链表详解

数据结构第三课 1. 前言2. 链表的概念以及结构3. 链表的分类4.链表的实现4.1 初始化结构4.2 尾插函数4.3 尾删函数4.4 头插函数4.5 头删函数4.6 开辟新节点4.7 销毁链表 5. 单链表OJ题目6. 顺序表和链表的区别7. 总结 1. 前言 &#x1f493;博主CSDN:杭电码农-NEO&#x1f493;…

五年开发经验前端程序员,刚入职一个月就要离职,我来聊聊看法

最近有一个新来的同事&#xff0c;估计又要离职了吧。从他的工作经历来看&#xff0c;大概有5年的前端工作经验&#xff0c;但是头发看起来挺少的&#xff0c;不知道是工作加班导致的&#xff0c;看他的性格不太像是经常加班的。 他这个人就是我们公司人事面试的&#xff0c;虽…

操作系统——进程管理

0.关注博主有更多知识 操作系统入门知识合集 目录 0.关注博主有更多知识 4.1进程概念 4.1.1进程基本概念 思考题&#xff1a; 4.1.2进程状态 思考题&#xff1a; 4.1.3进程控制块PCB 4.2进程控制 思考题&#xff1a; 4.3线程 思考题&#xff1a; 4.4临界资源与临…

躺平减脂减重法补充篇——无需控制碳水摄入的有效方法,另推一种健康的运动和防止老年慢性病的方式...

本文此前已经连续发表了六篇相关文章&#xff0c;内容确实比较多&#xff0c;最近又做了一组实验&#xff0c;进食了大量的锅巴&#xff0c;看看是否会带来体重的增加&#xff0c;每天进食量都不少于200克锅巴&#xff0c;对&#xff0c;4两重&#xff0c;而且是在每天正常进食…

SAPUI5 之XML Views (视图) 笔记

文章目录 官网 Walkthrough学习-XML Views视图案例要求&#xff1a;我们把上面通过index.html body的展示放在XML中展示1.0.1 新增view文件夹1.0.2 在xml文件中新增一个Text 文本1.0.3 在index.js中实例化view视图1.0.4 执行刷新浏览器1.0.5 调试界面分析结果 官网 Walkthrough…

假期给朋友介绍如何学习java和找工作的建议?

Java学习 一、学习Java的建议1. 学习Java基础知识2. 学习Java框架3. 学习Java Web开发4. 学习Java数据库编程5. 学习Java工具6.学习Java中的多线程技术6. 练习编程 二、找工作的建议1. 准备好简历2. 寻找工作机会3. 准备面试4. 提高自己的技能5. 关注行业动态 学习Java和找工作…

第十九章 观察者模式

文章目录 前言普通方式解决问题CurrentConditions 显示当前天气情况WeatherData 管理第三方Clint 测试 一、观察者模式(Observer)原理完整代码SubjectObserverWeatherData implements SubjectCurrentConditions implements ObserverBaiduSite implements ObserverClint 前言 普…

《软件工程教程》(第2版) 主编:吴迪 马宏茹 丁万宁 第十章课后习题参考答案

第十章 面向对象设计 课后习题参考答案 一、单项选择题 &#xff08;1&#xff09;A &#xff08;2&#xff09;B &#xff08;3&#xff09;B &#xff08;4&#xff09;D &#xff08;5&#xff09;A &#xff08;6&#xff09;C&#xff08;7&#xff09;D &#xff0…

【学习心得】Python多版本控制

问题描述&#xff1a;本文主要解决Windows系统下的多个Python版本共存问题。 &#xff08;一&#xff09;安装不同版本Python 官方下载链接&#xff1a;Python Releases for Windows | Python.org 下载如图中所示的版本&#xff08;64位Windows系统可执行安装包版本&#xff0…

赞!数字中国建设峰会上的金仓风采

4月30日&#xff0c;第六届数字中国建设成果展览会圆满落幕。人大金仓深度参与本届峰会&#xff0c;在会上发布产品新版本&#xff0c;展出国产数据库前沿的行业解决方案和创新应用成果&#xff0c;出席国资央企SaaS应用服务共享平台伙伴签约仪式&#xff0c;吸引众多用户、伙伴…

面试官:你知道 Spring lazy-init 懒加载的原理吗?

普通的bean的初始化是在容器启动初始化阶段执行的&#xff0c;而被lazy-init修饰的bean 则是在从容器里第一次进行context.getBean(“”)时进行触发。 Spring 启动的时候会把所有bean信息(包括XML和注解)解析转化成Spring能够识别的BeanDefinition并存到Hashmap里供下面的初始…

k210单片机定时器的应用

定时器应该是一个单片机的标准配置&#xff0c;所以k210也是有的&#xff0c;拥有3个定时器&#xff0c;具体的使用方法我们往下看&#xff1a; 分步介绍&#xff1a; 首先是相关模块的使用 构造函数&#xff1a; machine.Timer(id,channel,modeTimer.MODE_ONE_SHOT,period100…

【7. ROS 中的 IMU 惯性测量单元消息包】

欢迎大家阅读2345VOR的博客【6. 激光雷达接入ROS】&#x1f973;&#x1f973;&#x1f973; 2345VOR鹏鹏主页&#xff1a; 已获得CSDN《嵌入式领域优质创作者》称号&#x1f47b;&#x1f47b;&#x1f47b;&#xff0c;座右铭&#xff1a;脚踏实地&#xff0c;仰望星空&#…

vue3回到上一个路由页面

学习链接 Vue Router获取当前页面由哪个路由跳转 在Vue3的setup中如何使用this beforeRouteEnter 在这个路由方法中不能访问到组件实例this&#xff0c;但是可以使用next里面的vm访问到组件实例&#xff0c;并通过vm.$data获取组件实例上的data数据getCurrentInstance 是vue3提…

Java --- springboot2请求参数处理

目录 一、请求参数处理 1.1、请求映射 1.2、自定义请求规则 1.3、请求处理 1.4、普通参数与基本注解 1.4.1、注解 1.5、参数处理原则 1.6、复杂参数 1.7、自定义参数对象 1.8、自定义Converter 一、请求参数处理 1.1、请求映射 // RequestMapping(value "…

c#笔记-下载编辑器

IDE IDE是指集成开发环境&#xff08;Integrated Development Environment&#xff09;&#xff0c;是一种将软件开发所需的软件组合在一起&#xff0c;可以从同一操作界面以统一的操作方式使用的软件包。通常包括代码编辑器、编译器、链接器、调试器、测试工具、版本管理软件等…

自动化运维工具一Ansible Playbook语法实战

目录 一、Ansible Playbook剧本初识 1.1 Ansible Playbook 基本概述 1.1.1 什么是playbook 1.1.2 Ansible playbook 与AD-Hoc的关系 1.2 Ansible Playbook 书写格式 1.2.1安装NFS 服务 1.3 Playbook变量详解 1.3.1 使用 vars定义变量 1.3.2 使用 vars_flies定义变量 …

Java每日一练(20230501)

目录 1. 路径交叉 &#x1f31f;&#x1f31f; 2. 环形链表 &#x1f31f;&#x1f31f; 3. 被围绕的区域 &#x1f31f;&#x1f31f; &#x1f31f; 每日一练刷题专栏 &#x1f31f; Golang每日一练 专栏 Python每日一练 专栏 C/C每日一练 专栏 Java每日一练 专栏…