文章目录
线性表
- 线性表的顺序存储(顺序表)
- 线性表的链式存储(链表)
线性表的定义: - 1、线性表(List)是零个或多个数据元素的集合
- 2、线性表中的数据元素之间是有顺序的
- 3 、线性表中的数据元素的类型必须相同
- 4、线性表中的数据元素个数是有限的
1、顺序表(动态数组)
1.1、定义:
1.2、算法
-
1、效果数组变量pBase指向一些后,数组里面不再是垃圾值
void InitArray(struct Array pArr,int capacity);* -
2、判断是否为满
bool IsFull(struct Array pArr);* -
3、追加不满时追加
void AppendArray(struct Array pArr,int val);* -
4、判断数组是否为空
bool IsEmpty(struct Array pArr);* -
5、输出数组的中的数据
void ShowArray(struct Array pArr);* -
6、计算数组的容量
int CapacityArray(struct Array pArr);* -
7、计算素组的长度有效元素的个数
int LengthArray(struct Array pArr);* -
8、插入 pos的值是从1开始即下标为0时是第一个元素
bool InsertArray(struct Array pArr,int pos,int val);* -
9、删除通过元素的位置
*bool DeleteByPosArray(struct Array pArr,int pos,int *val); ** -
10、查找返回元素的下标
int FindPosArray(struct Array pArr,int val);* -
11、删除通过值
bool DeleteByvalueArray(struct Array pArr,int val);* -
12、翻转
void InversionArray(struct Array pArr);* -
13、升序
void SortArray(struct Array pArr);* -
14、清空数组
void ClearArray(struct Array pArr);* -
15、释放
void DestoryArray(struct Array pArr);*
1.3实现
1.3.0定义数据类型
#include<stdio.h>
#include<stdlib.h>
#include<malloc.h>
struct Array
{
int* pBase;
int len;//当前数组有效元素的个数
int capacity;//数组的容量capacity
};
void test()//测试函数
{
return 0;
}
int main()
{
test();
return 0;
}
1.3.1初始化
1.3.1.0思想
- 1、申请一块内存空间
- 2、使pArr->pBase指向那块内存空间
- 3、数组的长度置为零,容量由用户决定
1.3.1.1 功能代码:
void InitArray(struct Array* pArr,int capacity)//效果数组变量pBase指向一数据些后,数组里面不再是垃圾值,并且设定数组的长度
{
pArr->pBase = (int*)malloc(sizeof(int)*capacity);
if(NULL == pArr->pBase)//判断内存是否分配成功
{
printf("内存分配失败");
exit(-1);
}
pArr->capacity = capacity;
pArr->len = 0;
return ;//终止此函数
}
1.3.1.2 代码实现
#include<stdio.h>
#include<stdlib.h>
#include<malloc.h>
void InitArray(struct Array* pArr,int capacity);//效果数组变量pBase指向一些后,数组里面不再是垃圾值
struct Array
{
int* pBase;
int len;//当前数组有效元素的个数
int capacity;//数组的容量capacity
};
void test()//测试函数
{
return 0;
}
int main()
{
test();
return 0;
}
//数组的初始化
void InitArray(struct Array* pArr,int capacity)//效果数组变量pBase指向一数据些后,数组里面不再是垃圾值,并且设定数组的长度
{
pArr->pBase = (int*)malloc(sizeof(int)*capacity);
if(NULL == pArr->pBase)//判断内存是否分配成功
{
printf("内存分配失败");
exit(-1);
}
pArr->capacity = capacity;
pArr->len = 0;
return ;//终止此函数
}
1.3.2判断是否满
1.3.2.0思想
- 数组有效元素的个数是否等于数组的容量
pArr->capacity == pArr->len
1.3.2.1 功能代码:
bool IsFull(struct Array* pArr)//判断是否为满
{
if(pArr->capacity ==pArr->len)//数组长度和有效个数相同
return true;
else
return false;
}
1.3.2.2代码实现
#include<stdio.h>
#include<stdlib.h>
#include<malloc.h>
void InitArray(struct Array* pArr,int capacity);//效果数组变量pBase指向一些后,数组里面不再是垃圾值
bool IsFull(struct Array* pArr);//判断是否为满
struct Array
{
int* pBase;
int len;//当前数组有效元素的个数
int capacity;//数组的容量capacity
};
void test()//测试函数
{
return ;
}
int main()
{
test();
return 0;
}
//数组的初始化
void InitArray(struct Array* pArr,int capacity)//效果数组变量pBase指向一数据些后,数组里面不再是垃圾值,并且设定数组的长度
{
pArr->pBase = (int*)malloc(sizeof(int)*capacity);
if(NULL == pArr->pBase)//判断内存是否分配成功
{
printf("内存分配失败");
exit(-1);
}
pArr->capacity = capacity;
pArr->len = 0;
return ;//终止此函数
}
//判断是否为满
bool IsFull(struct Array* pArr)//判断是否为满
{
if(pArr->capacity ==pArr->len)//数组长度和有效个数相同
return true;
else
return false;
}
1.3.3追加
1.3.3.0思想
1.3.3.1 功能代码:
void AppendArray(struct Array* pArr,int val)//追加 条件不满时追加
{
if(IsFull(pArr))//满了就返回一个false程序运行结束
{
printf("数组已经满了没法追加");
return ;
}
pArr->pBase[pArr->len] = val;
(pArr->len)++;
return ;
/*有个难点len再初始函数中是零*/
}
1.3.3.2代码实现
#include<stdio.h>
#include<stdlib.h>
#include<malloc.h>
void InitArray(struct Array* pArr,int capacity);//效果数组变量pBase指向一些后,数组里面不再是垃圾值
bool IsFull(struct Array* pArr);//判断是否为满
void AppendArray(struct Array* pArr,int val);//追加不满时追加
struct Array
{
int* pBase;
int len;//当前数组有效元素的个数
int capacity;//数组的容量capacity
};
void test()//测试函数
{
return ;
}
int main()
{
test();
return 0;
}
//数组的初始化
void InitArray(struct Array* pArr,int capacity)//效果数组变量pBase指向一数据些后,数组里面不再是垃圾值,并且设定数组的长度
{
pArr->pBase = (int*)malloc(sizeof(int)*capacity);
if(NULL == pArr->pBase)//判断内存是否分配成功
{
printf("内存分配失败");
exit(-1);
}
pArr->capacity = capacity;
pArr->len = 0;
return ;//终止此函数
}
//判断是否为满
bool IsFull(struct Array* pArr)//判断是否为满
{
if(pArr->capacity ==pArr->len)//数组长度和有效个数相同
return true;
else
return false;
}
//追加
void AppendArray(struct Array* pArr,int val)//追加 条件不满时追加
{
if(IsFull(pArr))//满了就返回一个false程序运行结束
{
printf("数组已经满了没法追加");
return ;
}
pArr->pBase[pArr->len] = val;
(pArr->len)++;
return ;
/*有个难点len再初始函数中是零*/
}
1.3.4判断是否为空
1.3.4.0思想
- 判断数组的长度是否等于零
0 == pArr->len
1.3.2.1功能代码:
bool IsEmpty(struct Array* pArr)//判断有效元素个数是否为0
{
if(0 == pArr->len)
return true;
else
return false;
}
1.3.4.2代码实现
#include<stdio.h>
#include<stdlib.h>
#include<malloc.h>
void InitArray(struct Array* pArr,int capacity);//效果数组变量pBase指向一些后,数组里面不再是垃圾值
bool IsFull(struct Array* pArr);//判断是否为满
void AppendArray(struct Array* pArr,int val);//追加不满时追加
bool IsEmpty(struct Array* pArr);//判断数组是否为空
struct Array
{
int* pBase;
int len;//当前数组有效元素的个数
int capacity;//数组的容量capacity
};
void test()//测试函数
{
return ;
}
int main()
{
test();
return 0;
}
//数组的初始化
void InitArray(struct Array* pArr,int capacity)//效果数组变量pBase指向一数据些后,数组里面不再是垃圾值,并且设定数组的长度
{
pArr->pBase = (int*)malloc(sizeof(int)*capacity);
if(NULL == pArr->pBase)//判断内存是否分配成功
{
printf("内存分配失败");
exit(-1);
}
pArr->capacity = capacity;
pArr->len = 0;
return ;//终止此函数
}
//判断是否为满
bool IsFull(struct Array* pArr)//判断是否为满
{
if(pArr->capacity ==pArr->len)//数组长度和有效个数相同
return true;
else
return false;
}
//追加
void AppendArray(struct Array* pArr,int val)//追加 条件不满时追加
{
if(IsFull(pArr))//满了就返回一个false程序运行结束
{
printf("数组已经满了没法追加");
return ;
}
pArr->pBase[pArr->len] = val;
(pArr->len)++;
return ;
/*有个难点len再初始函数中是零*/
}
//判断数组是否为空
bool IsEmpty(struct Array* pArr)//判断有效元素个数是否为0
{
if(0 == pArr->len)
return true;
else
return false;
}
1.3.5输出数组
1.3.5.0思想
- 1、判断数组是否为空,空则返回
- 2、遍历数组知道循环变量小于数组的有效元素的个数(len-1为数组最后一个值的下标)
i = 0;i < pArr->len; i++
1.3.5.1功能代码
void ShowArray(struct Array* pArr)//输出数组的中的数据
{
int i;
if(NULL == pArr)
return ;//健壮性
if(IsEmpty(pArr))
{
printf("动态数组为空");
return;//退出函数
}
else
{
for(i = 0;i < pArr->len;i++)//有效元素个数为1时它的下标为0
printf("第%d个元素即下标为%d的元素值为 %d\n",i+1,i,pArr->pBase[i]);
printf("\n");
}
1.3.5.2代码实现
#include<stdio.h>
#include<stdlib.h>
#include<malloc.h>
void InitArray(struct Array* pArr,int capacity);//效果数组变量pBase指向一些后,数组里面不再是垃圾值
bool IsFull(struct Array* pArr);//判断是否为满
void AppendArray(struct Array* pArr,int val);//追加不满时追加
bool IsEmpty(struct Array* pArr);//判断数组是否为空
void ShowArray(struct Array* pArr);//输出数组的中的数据
struct Array
{
int* pBase;
int len;//当前数组有效元素的个数
int capacity;//数组的容量capacity
};
void test()//测试函数
{
struct Array arr;
int i ;
InitArray(&arr,10);
for(i = 5;i<10;i++)
{
AppendArray(&arr,i);
}
printf("======判断数组是否为空======\n\n");
if(IsEmpty(&arr))
printf("数组为空\n");
else
printf("数组不为空\n");
printf("======打印数组中的元素======\n\n");
ShowArray(&arr);
return ;
}
int main()
{
test();
return 0;
}
void InitArray(struct Array* pArr,int capacity)//效果数组变量pBase指向一数据些后,数组里面不再是垃圾值,并且设定数组的长度
{
pArr->pBase = (int*)malloc(sizeof(int)*capacity);
if(NULL == pArr->pBase)//判断内存是否分配成功
{
printf("内存分配失败");
exit(-1);
}
pArr->capacity = capacity;
pArr->len = 0;
return ;//终止此函数
}
//判断是否为满
bool IsFull(struct Array* pArr)//判断是否为满
{
if(NULL == pArr)
return false;//健壮性
if(pArr->capacity ==pArr->len)//数组长度和有效个数相同
{
return true;
}
else
{
return false;
}
}
//追加
void AppendArray(struct Array* pArr,int val)//追加 条件不满时追加
{ if(NULL == pArr)
return ;//健壮性
if(IsFull(pArr))//满了就返回一个false程序运行结束
{
printf("数组已经满了没法追加");
return ;
}
pArr->pBase[pArr->len] = val;
(pArr->len)++;
return ;
/*有个难点len再初始函数中是零*/
}
//判断数组是否为空
bool IsEmpty(struct Array* pArr)//判断有效元素个数是否为0
{
if(NULL == pArr)
return -1;//健壮性
if(0 == pArr->len)
return true;
else
return false;
}
void ShowArray(struct Array* pArr)//输出数组的中的数据
{
int i;
if(NULL == pArr)
return ;//健壮性
if(IsEmpty(pArr))
{
printf("动态数组为空");
return;//退出函数
}
else
{
for(i = 0;i < pArr->len;i++)//有效元素个数为1时它的下标为0
printf("第%d个元素即下标为%d的元素值为 %d\n",i+1,i,pArr->pBase[i]);
printf("\n");
}
}
运行结果:
1.3.6求数组的容量
1.3.6.0思想
- 返回数组的容量
return pArr->capacity;
1.3.6.1功能代码
int CapacityArray(struct Array* pArr)//计算数组的容量
{
if(NULL == pArr)
return -1;//健壮性
return pArr->capacity;
}
1.3.6.2代码实现
#include<stdio.h>
#include<stdlib.h>
#include<malloc.h>
void InitArray(struct Array* pArr,int capacity);//效果数组变量pBase指向一些后,数组里面不再是垃圾值
bool IsFull(struct Array* pArr);//判断是否为满
void AppendArray(struct Array* pArr,int val);//追加不满时追加
bool IsEmpty(struct Array* pArr);//判断数组是否为空
void ShowArray(struct Array* pArr);//输出数组的中的数据
int CapacityArray(struct Array* pArr);//计算数组的容量
int LengthArray(struct Array* pArr);//计算素组的长度有效元素的个数
struct Array
{
int* pBase;
int len;//当前数组有效元素的个数
int capacity;//数组的容量capacity
};
void test()//测试函数
{
struct Array arr;
int i,c;
InitArray(&arr,10);
for(i = 5;i<10;i++)
{
AppendArray(&arr,i);
}
printf("======判断数组是否为空======\n\n");
if(IsEmpty(&arr))
printf("数组为空\n");
else
printf("数组不为空\n");
printf("======打印数组中的元素======\n\n");
ShowArray(&arr);
printf("======数组的容量======\n\n");
c = CapacityArray(&arr);
printf("数组的容量为: %d\n",c);
return ;
}
int main()
{
test();
return 0;
}
void InitArray(struct Array* pArr,int capacity)//效果数组变量pBase指向一数据些后,数组里面不再是垃圾值,并且设定数组的长度
{
pArr->pBase = (int*)malloc(sizeof(int)*capacity);
if(NULL == pArr->pBase)//判断内存是否分配成功
{
printf("内存分配失败");
exit(-1);
}
pArr->capacity = capacity;
pArr->len = 0;
return ;//终止此函数
}
//判断是否为满
bool IsFull(struct Array* pArr)//判断是否为满
{
if(NULL == pArr)
return false;//健壮性
if(pArr->capacity ==pArr->len)//数组长度和有效个数相同
{
return true;
}
else
{
return false;
}
}
//追加
void AppendArray(struct Array* pArr,int val)//追加 条件不满时追加
{ if(NULL == pArr)
return ;//健壮性
if(IsFull(pArr))//满了就返回一个false程序运行结束
{
printf("数组已经满了没法追加");
return ;
}
pArr->pBase[pArr->len] = val;
(pArr->len)++;
return ;
/*有个难点len再初始函数中是零*/
}
//判断数组是否为空
bool IsEmpty(struct Array* pArr)//判断有效元素个数是否为0
{
if(NULL == pArr)
return -1;//健壮性
if(0 == pArr->len)
return true;
else
return false;
}
void ShowArray(struct Array* pArr)//输出数组的中的数据
{
int i;
if(NULL == pArr)
return ;//健壮性
if(IsEmpty(pArr))
{
printf("动态数组为空");
return;//退出函数
}
else
{
for(i = 0;i < pArr->len;i++)//有效元素个数为1时它的下标为0
printf("第%d个元素即下标为%d的元素值为 %d\n",i+1,i,pArr->pBase[i]);
printf("\n");
}
}
int CapacityArray(struct Array* pArr)//计算数组的容量
{
if(NULL == pArr)
return -1;//健壮性
return pArr->capacity;
}
运行结果:
1.3.7求数组的长度
1.3.7.0思想
- 返回数组的长度
return pArr->len;
1.3.7.1功能代码
int LengthArray(struct Array* pArr)//计算素组的长度有效元素的个数
{
if(NULL == pArr)
return -1;//健壮性
return pArr->len;
}
1.3.7.2代码实现
#include<stdio.h>
#include<stdlib.h>
#include<malloc.h>
void InitArray(struct Array* pArr,int capacity);//效果数组变量pBase指向一些后,数组里面不再是垃圾值
bool IsFull(struct Array* pArr);//判断是否为满
void AppendArray(struct Array* pArr,int val);//追加不满时追加
bool IsEmpty(struct Array* pArr);//判断数组是否为空
void ShowArray(struct Array* pArr);//输出数组的中的数据
int CapacityArray(struct Array* pArr);//计算数组的容量
int LengthArray(struct Array* pArr);//计算素组的长度有效元素的个数
struct Array
{
int* pBase;
int len;//当前数组有效元素的个数
int capacity;//数组的容量capacity
};
void test()//测试函数
{
struct Array arr;
int i,c;
InitArray(&arr,10);
for(i = 5;i<10;i++)
{
AppendArray(&arr,i);
}
printf("======判断数组是否为空======\n\n");
if(IsEmpty(&arr))
printf("数组为空\n");
else
printf("数组不为空\n");
printf("======打印数组中的元素======\n\n");
ShowArray(&arr);
printf("======数组的容量======\n\n");
c = CapacityArray(&arr);
printf("数组的容量为: %d\n",c);
printf("======数组的长度======\n\n");
printf("数组的长度为: %d\n",LengthArray(&arr));
return ;
}
int main()
{
test();
return 0;
}
void InitArray(struct Array* pArr,int capacity)//效果数组变量pBase指向一数据些后,数组里面不再是垃圾值,并且设定数组的长度
{
pArr->pBase = (int*)malloc(sizeof(int)*capacity);
if(NULL == pArr->pBase)//判断内存是否分配成功
{
printf("内存分配失败");
exit(-1);
}
pArr->capacity = capacity;
pArr->len = 0;
return ;//终止此函数
}
//判断是否为满
bool IsFull(struct Array* pArr)//判断是否为满
{
if(NULL == pArr)
return false;//健壮性
if(pArr->capacity ==pArr->len)//数组长度和有效个数相同
{
return true;
}
else
{
return false;
}
}
//追加
void AppendArray(struct Array* pArr,int val)//追加 条件不满时追加
{
if(NULL == pArr)
return ;//健壮性
if(IsFull(pArr))//满了就返回一个false程序运行结束
{
printf("数组已经满了没法追加");
return ;
}
pArr->pBase[pArr->len] = val;
(pArr->len)++;
return ;
/*有个难点len再初始函数中是零*/
}
//判断数组是否为空
bool IsEmpty(struct Array* pArr)//判断有效元素个数是否为0
{