顺序表的基本操作

在学习了顺序表之后自己来构造一个具有一系列(增删改查)基操的顺序表和大家一起分享下

顺序表的定义

typedef struct//定义顺序表
{
	int length;//
	int Maxsize;
	int* data;
}SqList;

其中的int*data 是设立一个存放数据元素的数组指针 

 初始化创建顺序表

void InitList(SqList& L)//初始化顺序表
{
	L.data = (int*)malloc(InitSize * sizeof(int));
	L.length = 0;
	L.Maxsize = InitSize;
}

 用malloc函数现申请数量为InitSize的数据内存,length表明当前存储的数据个数,参数中要加&才能在原表中进行操作

 首次添加数据

void WriteList(SqList& L)//把元素放入顺序表
{
	printf("请输入你要创建的顺序表的长度:");
	scanf("%d", &L.length);
	printf("请输入%d个你要放入顺序表里的元素:", L.length);
	for (int i = 0; i < L.length; i++)
		scanf("%d", &L.data[i]);
}

插入和删除数据

bool ListInsret(SqList& L)//插入元素
{
	int i, e;
	printf("请输入要插入顺序表的元素和元素位置:");
	scanf("%d %d", &e, &i);
	if (i<1 || i>L.length + 1)
		return false;
	if (L.length > L.Maxsize)
		return false;
	for (int j = L.length; j >= i; j--)
	{
		L.data[j] = L.data[j - 1];
	}
	L.data[i - 1] = e;
	L.length++;
	printf("插入的元素是%d,插入的位置是%d\n", e, i);
	return true;
}

bool ListDelete(SqList& L)//删除操作
{
	int i, e;
	printf("请输入要删除的元素位置:");
	scanf("%d", &i);
	if (i<1 || i>L.length + 1)
		return false;
	e = L.data[i - 1];
	for (int j = i; j <= L.length-1; j++)
	{
		L.data[j - 1] = L.data[j];
	}
	L.length--;
	printf("删除的元素是%d,这个元素的位置是%d\n", e, i);
	return true;
}

查找(按位查找和按值查找)

bool GetElem(SqList& L)//按位查找
{
	int i;
	printf("你要找第几个元素:");
	scanf("%d", &i);
	if (i<1 || i>L.length + 1)
	{
		printf("查找失败\n");
		return false;
	}
	printf("第%d个元素是%d\n", i, L.data[i - 1]);
	return true;
}

void LocateElem(SqList& L)//按值查找
{
	int e;
	int k = 1;
	printf("输入你要查找的元素值:");
	scanf("%d", &e);
	for (int i = 0; i < L.length; i++)
		if (L.data[i] == e)
		{
			printf("找到了,是第%d个元素\n", i + 1);
			k = 0;
			break;
		}
	if (k)
		printf("找不到元素%d\n", e);
}

代码运行

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<stdlib.h>
#define InitSize 10

typedef struct//定义顺序表
{
	int length;//
	int Maxsize;
	int* data;
}SqList;

void InitList(SqList& L)//初始化顺序表
{
	L.data = (int*)malloc(InitSize * sizeof(int));
	L.length = 0;
	L.Maxsize = InitSize;
}

void WriteList(SqList& L)//把元素放入顺序表
{
	printf("请输入你要创建的顺序表的长度:");
	scanf("%d", &L.length);
	printf("请输入%d个你要放入顺序表里的元素:", L.length);
	for (int i = 0; i < L.length; i++)
		scanf("%d", &L.data[i]);
}

void IncreaseSize(SqList& L)//增加顺序表的长度
{
	int len;
	int* p = L.data;
	printf("请输入你要增加的顺序表的长度:");
	scanf("%d", &len);
	L.data = (int*)malloc((L.Maxsize + len) * sizeof(int));
	for (int i = 0; i < L.length; i++)
		L.data[i] = p[i];
	L.Maxsize = L.Maxsize + len;
	free(p);
}

bool ListInsret(SqList& L)//插入元素
{
	int i, e;
	printf("请输入要插入顺序表的元素和元素位置:");
	scanf("%d %d", &e, &i);
	if (i<1 || i>L.length + 1)
		return false;
	if (L.length > L.Maxsize)
		return false;
	for (int j = L.length; j >= i; j--)
	{
		L.data[j] = L.data[j - 1];
	}
	L.data[i - 1] = e;
	L.length++;
	printf("插入的元素是%d,插入的位置是%d\n", e, i);
	return true;
}

bool ListDelete(SqList& L)//删除操作
{
	int i, e;
	printf("请输入要删除的元素位置:");
	scanf("%d", &i);
	if (i<1 || i>L.length + 1)
		return false;
	e = L.data[i - 1];
	for (int j = i; j <= L.length-1; j++)
	{
		L.data[j - 1] = L.data[j];
	}
	L.length--;
	printf("删除的元素是%d,这个元素的位置是%d\n", e, i);
	return true;
}

bool GetElem(SqList& L)//按位查找
{
	int i;
	printf("你要找第几个元素:");
	scanf("%d", &i);
	if (i<1 || i>L.length + 1)
	{
		printf("查找失败\n");
		return false;
	}
	printf("第%d个元素是%d\n", i, L.data[i - 1]);
	return true;
}

void LocateElem(SqList& L)//按值查找
{
	int e;
	int k = 1;
	printf("输入你要查找的元素值:");
	scanf("%d", &e);
	for (int i = 0; i < L.length; i++)
		if (L.data[i] == e)
		{
			printf("找到了,是第%d个元素\n", i + 1);
			k = 0;
			break;
		}
	if (k)
		printf("找不到元素%d\n", e);
}

bool PrintList(SqList& L)//打印顺序表
{
	if (!L.data)
		return false;
	printf("顺序表里的元素有:");
	for (int i = 0; i < L.length; i++)
		printf("%d ", L.data[i]);
	printf("\n");
	return true;
}

void DestroyList(SqList& L)//销毁顺序表
{
	char a;
	getchar();
	printf("是否销毁顺序表(Y/N):");
	scanf("%c", &a);
	if (a == 'Y')
	{
		L.length = 0;
		L.Maxsize = 0;
		free(L.data);
		printf("顺序表已销毁\n");
	}
}

int Length(SqList& L)//求表长
{
	if (L.length == 0)
		return 0;
	return L.length;
}

int main()
{
	SqList L;
	InitList(L);
	WriteList(L);
	PrintList(L);
	IncreaseSize(L);
	ListInsret(L);
	PrintList(L);
	ListDelete(L);
	PrintList(L);
	GetElem(L);
	LocateElem(L);
	int len = Length(L);
	printf("顺序表的表长:%d\n", len);
	DestroyList(L);
	return 0;
}

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值