c/c++线性表实现附源码(超详解)

简介: c/c++线性表实现附源码(超详解)

*不是纯c语言有一部分c++的内容

*以图书管理系统为例子带你理解

线性表的基本概念:

具有相同数据类型的 n (n ≥ 0 n\ge0n≥0)个数据元素的有限序列在内存空间中各数据的存储位置是一个连续的存在。

线性表的特点

1存在唯一一个被称作第一个的数据元素

2存在唯一一个被称作最后一个的数据元素

3除第一个元素以外每个元素都有唯一的前驱

4除最后一个元素以外每个元素都有唯一的后继

3线性表的顺序表示

LOC(ai)=LOC(a1)+(i-)*l

看着挺复杂其实可以这样理解

数组是从第一个元素a[0]起的而我们把第一个元素称作1

即a[i]=i+1

4规范化

#define error -1
#difine ok 1

这样规范化书写可以让我们的操作是否成功可视化

5顺序表的存储结构

#define maxsize 100//顺序表的最大长度(这样写的好处是可以根据不同数据大小更改)
typedef struct //
{
    ElemType *date;//存储数据的地址
    int length;//记录当前线性表的长度
}SqList;//自定义一种结构体类型,它的名字是SqList
//ElemType是一种数据类型可以为int,char,struct等

举个例子如果写的是图书管理系统那么ElemType *date就指向book

typedef struct 
{
    char name[20];
    float price;
}library;
library book[maxsize];

6顺序表的初始化

status initlist (SqList &l)
{
    l.date=(ElemType *)malloc(sizeof( ElemType)*maxsize)//为顺序表分配一个maxsize大小的空间
    if(!l.date)//判断是否为空
    return error;
    l.length=0;//将空表长度设置为0
    return ok;
}

指针自身 = (指针类型*)malloc(sizeof(指针类型)*数据数量

同时还有另外一种写法c++

status initlist (SqList &l)
{
    l.date=new ElemType[maxsize];
    if(!l.date)
    return error;
    l.length=0;
    return ok;
}

7顺序表的取值

status getelem(SqList l,int i,ElemType &e)
{
    if(i<1 && i>maxsize)//判断的值是否合理
    return error;
    e=l.elem[i-1];//elem[i-1]的位置存储第i个数据
    return ok;
}

ElemType &e中的e可以是一个结构体类型的数据

其实还可以通过循环的方式输入数据以上述图书管理系统为例

status getelem(SqList l,int i)
{
    if(i<1 && i>maxsize)//判断的值是否合理
    return error;
    int j;
for(j=0;j<i;j++)//为线性表输入信息
{    
    scanf("%c",&l.date[j].name);
    scanf("%f",&l.date[j].price);
}
    return ok;//输入完毕返回
}

8线性表的查找

1按位查找

bool locateElem(SqList &l)
{
    int i;
    printf("你要找第几个元素:");
    scanf("%d", &i);
    if (i<1 || i>l.length + 1)//判断输入的i值是否合法
        {
            printf("查找失败\n");
            return error;//i值不合法
        }
    printf("第%d个元素是%d\n", i, L.data[i - 1]);
    return ok;
}

2按值查找

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);
}

9顺序表的插入

bool ListInsret(SqList &L)
{
    int i, e;
    printf("请输入要插入顺序表的元素和元素位置:");
    scanf("%d %d", &e, &i);
    if (i<1 || i>L.length + 1)//判断元素下标是否越界
        return error;
    if (l.length > l.maxsize)//判断顺序表存储空间是否满了
        return error;
    for (int j = l.length; j >= i; j--)
    {
        l.data[j] = l.data[j-1];//从后往前逐个后移元素
    }
    l.data[i-1] = e;//将新元素放入下标为i-1的位置
    l.length++;//表长+1
    printf("插入的元素是%d,插入的位置是%d\n", e, i);
    return ok;
}

10顺序表的删除

bool ListDelete(SqList &L)
{
    int i, e;
    printf("请输入要删除的元素位置:");
    scanf("%d",&i);
    if (i<1 || i>l.length + 1)//判断元素下标是否越界
        return false;
    if (!L.data)//判断是不是空表
    {
        printf("空表\n");
        return error;
    }
    e = l.data[i - 1];
    for (int j = i; j <= L.length; j++)
    {
        L.data[j-1] = L.data[j];
    }
    l.length--;//表长-1
    printf("删除的元素是%d,这个元素的位置是%d\n", e, i);
    return ok;
}

以上就是顺序表的增删改查本人初学如有错误请各位大佬指正


相关文章
|
13天前
|
存储 算法 测试技术
【C++数据结构——线性表】求集合的并、交和差运算(头歌实践教学平台习题)【合集】
本任务要求编写程序求两个集合的并集、交集和差集。主要内容包括: 1. **单链表表示集合**:使用单链表存储集合元素,确保元素唯一且无序。 2. **求并集**:遍历两个集合,将所有不同元素加入新链表。 3. **求交集**:遍历集合A,检查元素是否在集合B中存在,若存在则加入结果链表。 4. **求差集**:遍历集合A,检查元素是否不在集合B中,若满足条件则加入结果链表。 通过C++代码实现上述操作,并提供测试用例验证结果。测试输入为两个集合的元素,输出为有序集合A、B,以及它们的并集、交集和差集。 示例测试输入: ``` a c e f a b d e h i ``` 预期输出:
37 7
|
13天前
|
机器学习/深度学习 存储 C++
【C++数据结构——线性表】单链表的基本运算(头歌实践教学平台习题)【合集】
本内容介绍了单链表的基本运算任务,涵盖线性表的基本概念、初始化、销毁、判定是否为空表、求长度、输出、求元素值、按元素值查找、插入和删除数据元素等操作。通过C++代码示例详细解释了顺序表和链表的实现方法,并提供了测试说明、通 - **任务描述**:实现单链表的基本运算。 - **相关知识**:包括线性表的概念、初始化、销毁、判断空表、求长度、输出、求元素值、查找、插入和删除等操作。 - **测试说明**:平台会对你编写的代码进行测试,提供测试输入和预期输出。 - **通关代码**:给出了完整的C++代码实现。 - **测试结果**:展示了测试通过后的预期输出结果。 开始你的任务吧,祝你成功!
30 5
|
13天前
|
机器学习/深度学习 存储 C++
【C++数据结构——线性表】顺序表的基本运算(头歌实践教学平台习题)【合集】
本文档介绍了线性表的基本运算任务,涵盖顺序表和链表的初始化、销毁、判定是否为空、求长度、输出、查找元素、插入和删除元素等内容。通过C++代码示例详细展示了每一步骤的具体实现方法,并提供了测试说明和通关代码。 主要内容包括: - **任务描述**:实现顺序表的基本运算。 - **相关知识**:介绍线性表的基本概念及操作,如初始化、销毁、判定是否为空表等。 - **具体操作**:详述顺序表和链表的初始化、求长度、输出、查找、插入和删除元素的方法,并附有代码示例。 - **测试说明**:提供测试输入和预期输出,确保代码正确性。 - **通关代码**:给出完整的C++代码实现,帮助完成任务。 文档
27 5
|
23天前
|
编译器 C语言 C++
【c++丨STL】list模拟实现(附源码)
本文介绍了如何模拟实现C++中的`list`容器。`list`底层采用双向带头循环链表结构,相较于`vector`和`string`更为复杂。文章首先回顾了`list`的基本结构和常用接口,然后详细讲解了节点、迭代器及容器的实现过程。 最终,通过这些步骤,我们成功模拟实现了`list`容器的功能。文章最后提供了完整的代码实现,并简要总结了实现过程中的关键点。 如果你对双向链表或`list`的底层实现感兴趣,建议先掌握相关基础知识后再阅读本文,以便更好地理解内容。
29 1
|
2月前
|
C语言 C++ 容器
【c++丨STL】string模拟实现(附源码)
本文详细介绍了如何模拟实现C++ STL中的`string`类,包括其构造函数、拷贝构造、赋值重载、析构函数等基本功能,以及字符串的插入、删除、查找、比较等操作。文章还展示了如何实现输入输出流操作符,使自定义的`string`类能够方便地与`cin`和`cout`配合使用。通过这些实现,读者不仅能加深对`string`类的理解,还能提升对C++编程技巧的掌握。
101 5
|
3月前
|
存储 编译器 C++
【C++篇】揭开 C++ STL list 容器的神秘面纱:从底层设计到高效应用的全景解析(附源码)
【C++篇】揭开 C++ STL list 容器的神秘面纱:从底层设计到高效应用的全景解析(附源码)
96 2
|
5月前
|
存储 算法 数据可视化
【C++】C++旅游管理系统(源码+论文)【独一无二】
【C++】C++旅游管理系统(源码+论文)【独一无二】
|
5月前
|
存储 数据可视化 C++
【C++】C++ 职工信息管理系统(源码)【独一无二】
【C++】C++ 职工信息管理系统(源码)【独一无二】
128 3
|
5月前
|
搜索推荐 数据处理 文件存储
【C++】C++ 培训报名系统 (源码+论文)【独一无二】
【C++】C++ 培训报名系统 (源码+论文)【独一无二】
|
5月前
|
存储 C++
【C++】C++公司人事管理系统(源码)【独一无二】
【C++】C++公司人事管理系统(源码)【独一无二】
168 2