数据结构顺序表的使用

目录

一,什么是数据结构?

二,顺序表的概念和分类

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 小时前
34_数据结构_栈
c语言·开发语言·数据结构·人工智能·嵌入式硬件·算法
itman3012 小时前
C语言errno.h头文件:错误处理机制及errno变量特点说明
c语言·错误码·库函数·错误处理·errno.h
爱编码的小八嘎3 小时前
C语言完美演绎7-2
c语言
笨笨饿3 小时前
32_复变函数在工程中实际应用区别于联系
linux·服务器·c语言·人工智能·单片机·算法·学习方法
爱编码的小八嘎4 小时前
C语言完美演绎7-3
c语言
水饺编程4 小时前
第4章,[标签 Win32] :SysMets3 程序讲解04,垂直滚屏重绘
c语言·c++·windows·visual studio
水饺编程5 小时前
第4章,[标签 Win32] :SysMets3 程序讲解05,水平滚动
c语言·c++·windows·visual studio
Felven5 小时前
A. Redstone?
c语言
luj_17686 小时前
从R语言想起的,。。。
服务器·c语言·开发语言·经验分享·算法
三道渊6 小时前
C语言:二级指针及void与void*的区别
c语言·开发语言