《数据结构-C语言》顺序表
@
顺序表
结构定义
#include <stdio.h>
#include <malloc.h>
#include <stdlib.h>
#define OK 1
#define ERROR 0
#define OVERFLOW -1
#define YES 1
#define NO 0
#define MAX_SIZE 100 // 顺序表最大长度
typedef int ElemType;
typedef int Status;
#pragma warning(disable:4996)
/*
顺序表的类型定义
*/
typedef struct
{
ElemType* elem; // 指向数据元素的基地址
int length; // 顺序表的当前长度
}SequenceList;
初始化
/*
初始化顺序表
*/
Status InitList(SequenceList* L)
{
// 为顺序表分配空间
L->elem = (ElemType*)malloc(MAX_SIZE * sizeof(ElemType));
L->length = 0; // 空表长度为0
return OK;
}
创建表
/*
创建指定大小的顺序表
*/
void CreateSqList(SequenceList* L, int n)
{
for (int i = 0; i < n; i++) {
scanf("%d", &L->elem[i]);
L->length++;
}
}
求表长
/*
求顺序表L的长度
*/
int GetLength(SequenceList L)
{
return (L.length);
}
判断表是否为空
/*
判断顺序表L是否为空
*/
Status IsEmpty(SequenceList L)
{
if (L.length == 0)
return YES;
else
return NO;
}
取值
/*
获取顺序表中第i个数据元素的内容
*/
Status GetElem(SequenceList L, int i, ElemType* e)
{
if (i < 1 || i > L.length)
return ERROR;
*e = L.elem[i - 1]; // 第i-1个单元存储着第i个数据
return OK;
}
查找
/*
在顺序表中查找值为e的数据元素
*/
int LocateELem(SequenceList L, ElemType e)
{
for (int i = 0; i < L.length; i++)
if (L.elem[i] == e) {
return i + 1; // 第i个单元存储着第i+1个数据
}
return 0;
}
插入
/*
插入,将元素插入到指定位序(插在第 i 个元素之前,0<i<=len+1)
*/
Status InsertElem(SequenceList* L, int i, ElemType e)
{
if (i < 1 || i > L->length + 1)
return ERROR; // i值不合法
if (L->length == MAX_SIZE)
return ERROR; // 当前存储空间已满
for (int j = L->length - 1; j >= i - 1; j--) {
L->elem[j + 1] = L->elem[j]; // 插入位置及之后的元素后移
}
L->elem[i - 1] = e; // 将新元素e放入第i个位置
L->length++; //表长增1
return OK;
}
删除
/*
将顺序表中第i个数据元素删除
*/
Status DeleteElem(SequenceList* L, int i, ElemType* e)
{
if ((i < 1) || (i > L->length)) {
return ERROR; // 删除位置不合理
}
*e = L->elem[i - 1];
for (int j = i;j <= L->length - 1;j++) {
L->elem[j - 1] = L->elem[j];
}
L->length--;
return OK;
}
逆置
/*
将顺序表所有元素逆置,空间复杂度为O(1)
*/
void Reverse(SequenceList* L) {
int temp = 0;
int i = 0;
for (i = 0; i < (L->length) / 2; i++) {
temp = L->elem[i];
L->elem[i] = L->elem[(L->length) - i - 1];
L->elem[(L->length) - i - 1] = temp;
}
}
清空
/*
清空顺序表L
*/
void ClearList(SequenceList* L)
{
L->length = 0;
}
销毁
/*
销毁顺序表L
*/
void DestroyList(SequenceList* L)
{
if (L->elem)
free(L->elem);
}
遍历打印
/*
打印顺序表
*/
void PrintSqList(SequenceList L)
{
for (int i = 0; i < L.length; i++)
{
printf("%d", L.elem[i]);
if (i < L.length - 1) {
printf(" ");
}
}
}
测试
int main() {
// 测试数据:1 3 8 5 6 7 9 2
SequenceList Sq;
Status a1 = InitList(&Sq);
printf("初始化:\na1 = %d\n", a1);
CreateSqList(&Sq, 8);
PrintSqList(Sq);
ElemType e2 = 0;
Status a2 = GetElem(Sq, 2, &e2);
printf("\n\na2 = %d, e2 = %d\n\n", a2, e2);
ElemType e3 = 0;
Status a3 = DeleteElem(&Sq, 2, &e3);
PrintSqList(Sq);
printf("\n\n");
ElemType e4 = 666;
Status a4 = InsertElem(&Sq, 2, e4);
PrintSqList(Sq);
printf("\n\n");
Reverse(&Sq);
PrintSqList(Sq);
printf("\n\n");
ClearList(&Sq);
DestroyList(&Sq);
return 0;
}
测试结果:

《数据结构-C语言》顺序表的更多相关文章
- 数据结构C语言顺序表
#include <stdio.h> #include <stdlib.h> typedef int EmenType; typedef struct Node { int d ...
- 数据结构C语言版 表插入排序 静态表
数据结构C语言版 表插入排序.txt两个人吵架,先说对不起的人,并不是认输了,并不是原谅了.他只是比对方更珍惜这份感情./* 数据结构C语言版 表插入排序 算法10.3 P267-P270 编译 ...
- 【数据结构】之顺序表(Java语言描述)
之前总结过使用C语言描述的顺序表数据结构.在C语言类库中没有为我们提供顺序表的数据结构,因此我们需要自己手写,详细的有关顺序表的数据结构描述和C语言代码请见[我的这篇文章]. 在Java语言的JDK中 ...
- 【数据结构】之顺序表(C语言描述)
顺序表是线性表的一种,它将元素存储在一段连续的内存空间中,表中的任意元素都可以通过下标快速的获取到,因此,顺序表适合查询操作频繁的场景,而不适合增删操作频繁的场景. 下面是使用 C语言 编写的顺序表的 ...
- 五种编程语言解释数据结构与算法——顺序表1(理论与C语言实现)
1.线性表的分类 2.线性表的定义及其基本操作 2.1.定义:线性表是具有相同类型的n(n>=0)个元素的有序序列,其中n为表长,当n=0时,该表为空表. 2.3.线性表的逻辑结构为: 2.4. ...
- 五种编程语言解释数据结构与算法——顺序表3(JavaScript与Python语言实现)
7.JavaScript语言实现 7.1.用ES6语法编写顺序表类 //1.创建类 class MyList { //1. initList(&L):初始化表.构造一个空的线性表.放回值应该是 ...
- 【C语言--数据结构】线性顺序表
线性表的本质: 1.线性表(List)是零个或者多个数据元素的集合: 2.线性表中的数据元素之间是有顺序的: 3.线性表中的数据元素个数是有限的: 4.线性表中的数据元素的类型必须相同: 定义: 线性 ...
- 五种编程语言解释数据结构与算法——顺序表2(java与C++语言实现)
5.java实现方式: 5.1.顺序表的抽象结构 package com.xgp.顺序表; public interface MyList<T> { //1. initList(& ...
- C++数据结构学习之顺序表
顺序表是数据结构中最基本也是应用相当广泛的一种数据结构类型.它通常包含三个私有成分,即指向数据数组的头指针.当前表长以及表的实际容量.表的头指针通常指向数据数组的基地址,通过数组的形式进行访问数据数组 ...
- 数据结构 单链表&顺序表
顺序表: 一般使用数组(C语言中的数组采用顺序存储方式.即连续地址存储)来描述. 优点:在于随机访问元素, 缺点:插入和和删除的时候,需要移动大量的元素. 链表: 优点:插入或删除元素时很方便,使用灵 ...
随机推荐
- 【.NET】C#/.NET新建项目sln,增加src和test文件夹问题和解决方案
问题介绍 经常逛github找优秀的.NET项目看,看到github上的项目的层级有src test,sln放在外层.如下图: 发现自己再Visaul Studio新建的项目即使添加了src和te ...
- lec-4-Introduction to Reinforcement Learning
模仿学习imitation learning与RL的不同 模仿学习中需要有专家指导的信息 RL不需要访问专家信息 RL Definitions 奖励函数 马尔科夫决策链 只与上一个状态有关 目的 空间 ...
- 02-初识Verilog
1.开发环境搭建 需要使用的软件: QuartusII ModelSim Visio Notepad++ 2.初识Verilog 2.1 Verilog HDL简介 Verilog HDL是一种硬件描 ...
- C++面试八股文:C++中指针、引用、解引用和取地址有什么不同?
某日小二参加XXX科技公司的C++工程师开发岗位2面: 面试官:指针.引用.解引用和取地址是C++中的重要概念,请问它们在语法和语义上有所不同? 小二:指针是一个变量,它存储了一个内存地址. 小二:引 ...
- 在技术圈混,不知道这些你就 OUT 了
技术之路就是漫长的打怪升级,不断学习前人的踩坑经验才能提升自己,切忌闭门造车.所谓独乐乐不如众乐乐,强烈推荐以下公众号,让你的生活多点意思,希望小伙伴们能在 coding 的路上走的更远. OSC开源 ...
- 【python基础】循环语句-continue关键字
1.continue关键字 continue关键字的作用是:用来告诉 Python 跳过当前循环代码块中的剩余语句,然后继续进行下一轮循环. 其在while循环和for循环中的作用示意图如下 我们通过 ...
- 三分钟快速了解什么是MES系统
大家好,我是Edison. 近日我打算系统学习和整理一下MES/MOM系统相关的领域知识,从而构建我的业务域知识背景.万丈高楼平地起,我们先从快速了解什么是MES系统开始吧! 作为IT技术从业者,特别 ...
- mysql_三大范式
介绍 数据库的三大范式就是数据库的表应该如何设计,应该注意什么. 第一范式 要求每一张表都有一个主键,每一个字段都不可再分. 举例: id username address 1 张三 中国,北京 2 ...
- Spring配置动态数据库
前言 本文主要介绍使用spring boot 配置多个数据库,即动态数据库 开始搭建 首先创建一个SpringWeb项目--dynamicdb(spring-boot2.5.7) 然后引入相关依赖lo ...
- 13. 注解配置SpringMVC
使用配置类和注解代替web.xml和SpringMVC配置文件的功能 13.1.创建初始化类,代替web.xml 在Servlet3.0环境中,容器会在类路径中查找实现javax.servlet.Se ...