数据结构之顺序存储-顺序表的基本操作c/c++(创建、初始化、赋值、插入、删除、查询、替换、输出)

学习参考博文:http://t.csdnimg.cn/Qi8DD

学习总结,同时更正原博主在顺序表中插入元素的错误。

数据结构顺序表------基本代码实现(使用工具:VS2022):

cpp 复制代码
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
#define Size 7


//建表语句
typedef struct
{
	int* elem; //定义数组,动态分配
	int length;//定义数组的长度
	int size;  //定义数组的分配空间
}Sqlist;


//初始化线性结构顺序表
Sqlist InitList(Sqlist& L)   //返回类型为结构体
{
	L.elem = (int *)malloc(Size * sizeof(int));
	if (!L.elem)
		printf("申请储存空间失败");
	L.length = 0;
	L.size = Size;  //初始化顺序表的空间和长度
	return L;
}

//顺序表赋值
Sqlist assignment(Sqlist& L)
{
	int i;
	for (i = 0; i < L.size-2; i++)//给顺序表分配五个字符空间
	{
		L.elem[i] = i + 1;
		L.length++;   //顺序表长度
	}
	return L;
}

//输出顺序表储存情况
Sqlist Export(Sqlist L)
{
	printf("顺序表储存的情况如下:");
	for (int i = 0; i < L.length; i++)
	{
		printf("%d  ", L.elem[i]);
	}
	printf("\n");
	return L;
}

//插入数据
void ListInsert(Sqlist& L,int i, int e)  //i是插入的位置,e是插入的元素 
{
	if (i<1 || i>L.length + 1) //判断插入的数据是否合法
		exit(0);
	if (L.length >= Size)      //判断表的存储空间是否已满
		exit(0);
	for (int j = L.length - 1; j >= i - 1; j--)
		L.elem[j + 1] = L.elem[j];      //将第n位至第i位元素依次向右移动一个位置
	L.elem[i - 1] = e;     //将新元素e放到第i个位置
	L.length++;            //表长增加1
}

//删除元素
bool ListDelete(Sqlist& L, int i,int &e)
{
	if (i<1 || i>L.length)
		return false;
	e = L.elem[i - 1];
	for (int j = i; j <= L.length - 1; j++)
		L.elem[j - 1] = L.elem[j];
	L.length--;
	return true;
}


//查找元素
int LocateElem(Sqlist L, int e)
{
	for (int i = 0; i < L.length; i++)
	{
		if (L.elem[i] == e)
			return i + 1;  //找到了,返回元素的位置
	}
	return 0; //没找到,返回0
}

//替换指定数据
Sqlist Replace(Sqlist L, int a, int b)//将a替换成b
{
	int i = LocateElem(L, a);
	L.elem[i - 1] = b;
	return L;
}

//主函数
int main()
{
	Sqlist L;
	L = InitList(L);
	L = assignment(L);
	Export(L);
	printf("\n --------------------------- \n");
	int i;
	int e;
	printf("请输入要插入的位置:");
	scanf_s("%d", &i);
	printf("请输入要插入的元素:");
	scanf_s("%d", &e);
	if (i > L.size + 1 || i < 0)
	{
		printf("输入的数据有误\n");
		exit(0);
	}
    ListInsert(L, i, e);
	Export(L);//输出顺序表
	printf("\n");
	printf("\n --------------------------- \n");
	printf("请输入删除的位置:");
	scanf_s("%d", &i);
	if (i > L.size || i < 0)
	{
		printf("输入的位置错误\n");
		exit(0);
	}
	int a;
	ListDelete(L, i,a);
	printf("删除的元素是:%d\n", a);
	Export(L);

	printf("\n --------------------------- \n");
	printf("查找5的位置:");//查找5的位置
	int b = LocateElem(L, 5);
	printf("5的位置是:%d",b);
	Export(L);

	printf("\n --------------------------- \n");
	printf("用 55 替换 5\n");
	Replace(L, 5, 55);
	Export(L);
}
相关推荐
学不动CV了18 分钟前
数据结构---链表结构体、指针深入理解(三)
c语言·arm开发·数据结构·stm32·单片机·链表
tan77º18 分钟前
【Linux网络编程】Socket - UDP
linux·服务器·网络·c++·udp
GiraKoo1 小时前
【GiraKoo】C++14的新特性
c++
悠悠小茉莉1 小时前
Win11 安装 Visual Studio(保姆教程 - 更新至2025.07)
c++·ide·vscode·python·visualstudio·visual studio
坏柠1 小时前
C++ Qt 基础教程:信号与槽机制详解及 QPushButton 实战
c++·qt
泽02022 小时前
C++之红黑树认识与实现
java·c++·rpc
算法_小学生2 小时前
LeetCode 287. 寻找重复数(不修改数组 + O(1) 空间)
数据结构·算法·leetcode
岁忧2 小时前
(LeetCode 每日一题) 1865. 找出和为指定值的下标对 (哈希表)
java·c++·算法·leetcode·go·散列表
whoarethenext3 小时前
使用 C++ 实现 MFCC 特征提取与说话人识别系统
开发语言·c++·语音识别·mfcc
R-G-B3 小时前
【MFC】Combobox下拉框中4个选项,运行后点击下拉框选项不能全部展示出来,只能显示2个选项,需要垂直滚动条滚动显示其余选项
c++·mfc