数据结构顺序表的使用

目录

一,什么是数据结构?

二,顺序表的概念和分类

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

相关推荐
海阔天空任鸟飞~2 小时前
蓝汛-获取mic dump数据
c语言·蓝汛
AMoon丶2 小时前
Golang--多种控制结构详解
java·linux·c语言·开发语言·后端·青少年编程·golang
智者知已应修善业2 小时前
【不用第三变量交换2个数】2024-10-18
c语言·数据结构·c++·经验分享·笔记·算法
时光の尘2 小时前
嵌入式面试八股文(二十)·C语言关键字相关知识点速通(static、const、volatile、struct、enum、union)
c语言·const·static·union·volatile·struct·enum
会编程的土豆2 小时前
c语言时间戳从入门到精通
linux·c语言·算法
悠哉悠哉愿意3 小时前
【单片机学习笔记】math库函数补充
c语言·笔记·单片机·学习
炸膛坦客3 小时前
单片机/C语言八股:(五)32/64 位系统中,C/C++各变量类型所占字节数
c语言·开发语言·c++
会编程的土豆3 小时前
C语言实现:影院票务管理系统(铠甲怪兽管理系统)(详细解析+效果展示)C语言实现:影院票务管理系统(铠甲怪兽管理系统)(详细解析+效果展示)
c语言·开发语言·课程设计·项目·管理系统
2301_789015623 小时前
DS进阶:红黑树
c语言·开发语言·数据结构·c++·算法·r-tree·lsm-tree