数据结构之顺序表(动态数组)

本文详细介绍了线性表的顺序存储结构——顺序表,包括其定义、算法实现,如初始化、判断是否满、追加、判断是否为空、输出数组、求容量和长度、插入、删除、查找、排序等操作,并提供了相应的代码实现和应用说明。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

线性表

  • 线性表的顺序存储(顺序表)
  • 线性表的链式存储(链表)
    线性表的定义:
  • 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
{
  
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值