目录
一,什么是数据结构?
数据结构是计算机存储、组织数据的方式,是指相互之间存在一种或多种特定关系的数组元素的集合。
通过数据结构,可以将数据有效的组织和管理在一起,可以帮助我们更好的实现对数据的增删查改操作。
数组就是一种最基础的数据结构。
二,顺序表的概念和分类
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
