IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> C++知识库 -> 顺序表创建与增删(c语言实现) -> 正文阅读

[C++知识库]顺序表创建与增删(c语言实现)

顺序表定义:用顺序存储的方式实现线性表
顺序存储定义:把逻辑上相邻的元素存储在物理位置上也相邻的存储单元中,元素之间的关系由存储单元的邻接关系来体现。
线性表定义:线性表具有相同特性的数据元素的一个有限序列。

静态顺序表创建

1、创建数据

2、初始化顺序表

typedef struct {                //创建数据
	ElemType data[MaxSize];   //ElemType数据类型 
	int length;
}SqList;
void InitList(SqList &L) {         //初始化一个顺序表
	for (int i = 0;i < MaxSize;i++) {//MaxSize为最大容量
		L.data[i] = 0
		L.length = 0;
int main() {
	SqList L;//声明一个顺序表
	InitList(L);//初始化一个顺序表
	return 0;
}

动态顺序表创建

#define _CRT_SECURE_NO_WARNINGS 
#define MAX 200
typedef struct SqList {
	int* data;			  //指向动态数组的指针
	int MaxSize;		 //最大容量
	int length;			//当前长度
}L;

初始化

SqList* InitList(SqList *L) {
	L->data = (SqList*)malloc(sizeof(int)*MAX);  //指针指向一块空间
	L->MaxSize = MAX;
	L->length = 0;           //初始长度为0
}

增加动态数组的长度

void IncreaseSize (SqList* W, int len){
	int* p = W->data;         //存储原来空间的数据
		W->data = (int*)malloc((W->MaxSize + len) * sizeof(int));
		for (int i = 0;i < W->length;i++) {
			W->data[i] = p[i];        //将数据复制到新区域
		}
		W->MaxSize = W->MaxSize + len;
		free(p);	
}

顺序表插入操作

//在中间插入几个元素
bool ListInsert(L, int e, int i){//e为插入点 i为插入数值
	if (e<1 || i>L.length + 1)//判断e的范围是否正确 
		return false
		if (L.length >= MaxSize)//当前存储空间已满,不能插入 
			return false;
	for (int j = L.lenth;j >= e;j--) {// 从L.length 循环至插入点
		L.data[j] = L.data[j - 1];//前后换位
		L.data[j - 1] = i;//插入点换成插入值
		L.length++;//替换后总长度+1
		return true;
	}
}

顺序表删除操作

bool ListDelete(SqList* L, int i, int* e) {
	if (i<1 || i>L.length)
		return false;
	e = L.data[i - 1];
	if (int j = i;j < L.length;j++))
	L.data[j - 1] = L.data[j];
	L.length--;
	return true;
}

  C++知识库 最新文章
【C++】友元、嵌套类、异常、RTTI、类型转换
通讯录的思路与实现(C语言)
C++PrimerPlus 第七章 函数-C++的编程模块(
Problem C: 算法9-9~9-12:平衡二叉树的基本
MSVC C++ UTF-8编程
C++进阶 多态原理
简单string类c++实现
我的年度总结
【C语言】以深厚地基筑伟岸高楼-基础篇(六
c语言常见错误合集
上一篇文章      下一篇文章      查看所有文章
加:2021-10-30 12:23:34  更:2021-10-30 12:25:42 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 5:43:23-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码