C语言下顺序表的实现(增删改查和一些其他接口)

文章目录

      • 1.头函数
      • 2.创建顺序表
      • 3.初始化
      • 4.插入
      • 5.查找
      • 6.删除
        • 6.1删除特定值数据
        • 6.2删除位置值数据
      • 7.修改
      • 8.功能性接口
        • 8.1打印顺序表
        • 8.2获取数据长度
        • 8.3获取顺序表容量
        • 8.4获取位置下的数据
        • 8.5清空数据
        • 8.6销毁顺序表
      • 9.内部接口
        • 9.1判空
        • 9.2判满
        • 9.3扩容

1.头函数

#include
#include

2.创建顺序表

#define INIT_SIZE 10//宏定义初始容量为10

typedef struct DSeqlist
{
     
	int* array;//指向动态创建的内存
	int size;//有效数据个数
	int capacity;//数组容量
}DSeqlist,*PDSeqlist;

3.初始化

//顺序表初始化
void InitDSeqlist(PDSeqlist plist)
{
     
	plist->array = (int*)malloc(INIT_SIZE * sizeof(int));//给数组开辟动态内存,大小为10
	plist->size = 0;//初始化有效数据个数为0
	plist->capacity = INIT_SIZE;//初始化容量为10
}

4.插入

//根据位置将数据插入顺序表中
bool InsertDSeqlist(PDSeqlist plist, int val, int pos)
{
     
	//如果位置小于0或者大于最后一个位置的后一个,即数据不连续存放则插入失败
	if (pos < 0 || pos > plist->size + 1)
	{
     
		return false;
	}
	//向后移动数据
	for (int i = pos;i < plist->size;i++)
	{
      
		plist->array[i + 1] = plist->array[i];
	}
	plist->array[pos] = val;//插入数据
	plist->size++;//有效数据+1
	return true;
}

5.查找

//查找数据并返回下标
int SearchDSeqlist(PDSeqlist plist, int key)
{
     
	//遍历顺序表,直到找到第一个数据并返回其下标,否则返回-1
	for (int i = 0;i < plist->size;i++)
	{
     
		if (plist->array[i] == key)
		{
     
			return i;
		}
	}
	return -1;
}

6.删除

6.1删除特定值数据

//删除数据(查找第一次出现的数据)
bool DeleteValDSeqlist(PDSeqlist plist, int key)
{
     
	int pos = SearchDSeqlist(plist, key);//得到删除数据的下标
	if (pos < 0 || pos > plist->size)
	{
     
		return false;
	}
	int tmp;
	//将需要删除的数据直接覆盖,即后面的数据向前移动
	for (int i = pos;i < plist->size;i++)
	{
     
		plist->array[i] = plist->array[i + 1];
	}
	plist->size--;//有效数据个数-1
	return true;
}

6.2删除位置值数据

//查找位置,删除数据
bool DeletePosDSeqlist(PDSeqlist plist, int pos)
{
     
	//判断位置值是否合法
	if (pos < 0 || pos > plist->size)
	{
     
		return false;
	}
	//将位置后的数据向前移动,即覆盖删除数据
	for (int i = pos;i < plist->size;i++)
	{
     
		plist->array[i] = plist->array[i + 1];
	}
	plist->size--;//有效数据-1
	return true;
}

7.修改

//修改数据
bool SetPosDSeqlist(PDSeqlist plist, int pos, int NewVal)
{
     
	if (pos < 0 || pos > plist->size)
	{
     
		return false;
	}
	plist->array[pos] = NewVal;//直接将位置的数据替换成新数据即可
	return true;
}

8.功能性接口

8.1打印顺序表

//打印顺序表
void Show(PDSeqlist plist)
{
     
	//将所有有效数据输出
	for (int i = 0;i < plist->size;i++)
	{
     
		printf("%d ", plist->array[i]);
	}
	printf("\n");
}

8.2获取数据长度

//获取有效数据个数
int GetSize(PDSeqlist plist)
{
     
	return plist->size;
}

8.3获取顺序表容量

//获取容量
int GetCapacity(PDSeqlist plist)
{
     
	return plist->capacity;
}

8.4获取位置下的数据

//获取位置下的数据
int GetValue(PDSeqlist plist, int pos)
{
     
	return plist->array[pos];
}

8.5清空数据

//清空数据
void Clear(PDSeqlist plist)
{
     
	plist->size = 0;
}

8.6销毁顺序表

//销毁,静态开辟的顺序表在程序结束之后会由系统回收
void DestroyDSeqlist(PDSeqlist plist)
{
     
	free(plist->array);//释放动态内存
	plist->array = nullptr;//将顺序表的数组指针置空,避免成为野指针
	plist->capacity = 0;
	plist->size = 0;
}

9.内部接口

9.1判空

//判空
bool IsEmpty(PDSeqlist plist)
{
     
	return plist->size == 0;
}

9.2判满

//判满
static bool IsFull(PDSeqlist plist)
{
     
	return plist->size == plist->capacity;
}

9.3扩容

//扩容
bool Increase(PDSeqlist plist)
{
     
	//此处我是扩大了两倍,也有一些是扩大1.5倍等等,目的是避免出现空间浪费
	plist->array = (int*)realloc(plist->array,sizeof(int) * plist->capacity * 2);
	//此处判断一下是否扩容成功,开辟内存空间都有可能失败
	if (plist->array == nullptr)
	{
     
		printf("realloc fail\n");
		return false;
	}
	plist->capacity *= 2;
	return true;
}

你可能感兴趣的:(数据结构,C语言,数据结构,c语言)