数据结构——顺序表(C语言版)

顺序表是数据结构中最基本的一种线性表,它以一段连续的存储空间来存储数据元素,元素之间的顺序由它们在内存中的位置来决定。在C语言中,我们通常使用数组来实现顺序表。

目录

顺序表的结构定义

顺序表的基本操作

应用实例


顺序表的结构定义

首先,我们需要定义一个结构体来表示顺序表,包括数据元素数组和当前元素个数等信息:

cpp 复制代码
#define MAX_SIZE 100 // 定义顺序表的最大容量

typedef struct {
    int data[MAX_SIZE]; // 数据元素数组
    int length; // 当前元素个数
} SeqList;
顺序表的基本操作
  1. 初始化顺序表

    cpp 复制代码
    void initSeqList(SeqList *L) {
     L->length = 0;
    }
  2. 插入元素

    cpp 复制代码
    int insert(SeqList *L, int index, int element) {
     if (index < 0 || index > L->length || L->length == MAX_SIZE) {
         return 0; // 插入失败
     }
     for (int i = L->length - 1; i >= index; i--) {
         L->data[i + 1] = L->data[i];
     }
     L->data[index] = element;
     L->length++;
     return 1; // 插入成功
    }
  3. 删除元素

    cpp 复制代码
    int delete(SeqList *L, int index) {
     if (index < 0 || index >= L->length) {
         return 0; // 删除失败
     }
     for (int i = index; i < L->length - 1; i++) {
         L->data[i] = L->data[i + 1];
     }
     L->length--;
     return 1; // 删除成功
    }
  4. 查找元素

    cpp 复制代码
    int search(SeqList L, int element) {
     for (int i = 0; i < L.length; i++) {
         if (L.data[i] == element) {
             return i; // 返回元素位置
         }
     }
     return -1; // 元素不存在
    }
应用实例
cpp 复制代码
#include <stdio.h>

int main() {
    SeqList list;
    initSeqList(&list);

    insert(&list, 0, 10);
    insert(&list, 1, 20);
    insert(&list, 2, 30);

    printf("顺序表中的元素为: ");
    for (int i = 0; i < list.length; i++) {
        printf("%d ", list.data[i]);
    }
    printf("\\n");

    delete(&list, 1);

    printf("删除元素后的顺序表为: ");
    for (int i = 0; i < list.length; i++) {
        printf("%d ", list.data[i]);
    }
    printf("\\n");

    int index = search(list, 30);
    if (index != -1) {
        printf("元素30的位置为: %d\\n", index);
    } else {
        printf("元素30不存在\\n");
    }

    return 0;
}

通过以上实现,我们可以在C语言中创建、插入、删除和查找顺序表中的元素。顺序表的简单实现不仅有助于理解数据结构的基本概念,还可以为解决实际问题提供基础。

顺序表作为线性表的开头部分,对于我们后续学习数据结构中还是很重要的,需要我们把它学好,本篇文章也只是点了一下知识点并给出少许例子,更多的知识还需要我们自己去探索学习!

感谢观看,还请点一个小小的赞吧!!!

相关推荐
轻口味36 分钟前
命名空间与模块化概述
开发语言·前端·javascript
晓纪同学2 小时前
QT-简单视觉框架代码
开发语言·qt
威桑2 小时前
Qt SizePolicy详解:minimum 与 minimumExpanding 的区别
开发语言·qt·扩张策略
飞飞-躺着更舒服2 小时前
【QT】实现电子飞行显示器(简易版)
开发语言·qt
明月看潮生2 小时前
青少年编程与数学 02-004 Go语言Web编程 16课题、并发编程
开发语言·青少年编程·并发编程·编程与数学·goweb
明月看潮生2 小时前
青少年编程与数学 02-004 Go语言Web编程 17课题、静态文件
开发语言·青少年编程·编程与数学·goweb
Java Fans2 小时前
C# 中串口读取问题及解决方案
开发语言·c#
盛派网络小助手2 小时前
微信 SDK 更新 Sample,NCF 文档和模板更新,更多更新日志,欢迎解锁
开发语言·人工智能·后端·架构·c#
Chinese Red Guest2 小时前
python
开发语言·python·pygame
一棵星3 小时前
Java模拟Mqtt客户端连接Mqtt Broker
java·开发语言