数据结构顺序表的使用

目录

一,什么是数据结构?

二,顺序表的概念和分类

1,线性表

2,顺序表

3,顺序表的分类

三,动态顺序表的增删查改

四,通讯录项目


一,什么是数据结构?

数据结构是计算机存储、组织数据的方式,是指相互之间存在一种或多种特定关系的数组元素的集合。

通过数据结构,可以将数据有效的组织和管理在一起,可以帮助我们更好的实现对数据的增删查改操作。

数组就是一种最基础的数据结构。

二,顺序表的概念和分类

1,线性表

线性表是n个具有相同特性的数据元素的有限序列。线性表就是一种数据结构,常见的线性表有:

顺序表、链表、栈、队列、字符串......

线性表在逻辑结构上是连续的,在物理结构上不一定是连续的。

2,顺序表

顺序表是一种线性表的顺序存储结构。他用一组地址连续的存储单元来依次存储顺序表中的数据元素,使得在逻辑结构上连续的元素在物理结构上也连续。

顺序表在底层上也是数组,不过提供了许多修改数组的操作(增删查改)。

3,顺序表的分类

1,静态顺序表的定义:

struct SepList

{

int arr[100]; //开辟的定长数组

int size; //顺序表中有效元素的个数

};

2,动态顺序表的定义:

struct SepList

{

int* arr; //动态开辟的数组空间

int size; //顺序表中有效元素的个数

int capaticy; //开辟的空间的大小

};

哪一种顺序表更适合用来存储数据?

静态顺序表的大小是确定的,不能进行更改。

如果开辟的空间过大,就有可能造成大量的空间的浪费。

如果开辟的空间过小,就有可能导致开辟的空间不够使用。

但是如果使用动态顺序表,数组的空间可以进行更改,面对不同情况时,就可以通过调整大小,解决不同的大小问题。

因此相对于静态顺序表,动态顺序表更适合存储数据

三,动态顺序表的增删查改

头文件SepList.h:

源文件Seplist.c:

源文件code.c

四,通讯录项目

通讯录的功能:

1,能够保存用户的信息:姓名、性别、年龄、电话、住址

2,增加联系人的信息

3,删除联系人的信息

4,查找指定联系人

5,修改指定联系人

6,显示指定联系人的信息

通讯录的本质上是顺序表,不过将顺序表中的元素更改为自定义类型的结构体。

故可以在顺序表的基础上进行更改,使之变成通讯录 。

项目代码全过程 :

1,SepList.h :

2,SepList.c

3,Contact.h

4,Contact.c

5,code.c

相关推荐
我星期八休息7 小时前
Linux系统编程—基础IO
linux·运维·服务器·c语言·c++·人工智能·算法
kkeeper~9 小时前
0基础C语言积跬步之深入理解指针(4)
c语言·开发语言
学会870上岸华师10 小时前
C 语言程序设计——第一章课后编程题
c语言·开发语言·学习·算法
wangjialelele11 小时前
【SystemV】基于建造者模式的信号量
linux·c语言·c++·算法·建造者模式
朔北之忘 Clancy12 小时前
2026 年 3 月青少年软编等考 C 语言一级真题解析
c语言·开发语言·c++·学习·青少年编程·题解·一级
不剪发的Tony老师13 小时前
Code::Blocks:一款免费开源的C/C++/Fortran集成开发环境
c语言·c++·ide
三品吉他手会点灯16 小时前
C语言学习笔记 - 32.嵌入式C语言学习阶段对初学编程者的建议
c语言·开发语言·笔记·学习
谙弆悕博士16 小时前
快速学C语言——第17章:多文件编程与头文件规范
c语言·开发语言·算法·学习方法·头文件·多文件编程
三品吉他手会点灯16 小时前
C语言学习笔记 - 31.数据类型 - 基本输入输出函数printf与scanf
c语言·开发语言·笔记·学习