Bootstrap

数据结构实战之线性表(一)

一.线性表的定义和特点

  1. 线性表的定义

  • 线性表是一种数据结构,它包含了一系列具有相同特性的数据元素,数据元素之间存在着顺序关系。例如,26个英文字母的字符表 ( (A, B, C, ....., Z) ) 就是一个线性表,其中每个字母就是一个数据元素。
  • 在线性表中,每个数据元素可以包含若干个数据项。例如,学生基本信息表中的每个学生可以视为一个数据元素,而这些元素包括学号、姓名、性别、籍贯、专业等数据项。
  • 2.线性表的特性

  • 在线性表中,虽然每个数据元素可能不同,但是它们都属于同一数据对象,具有相同的特性,且相邻的数据元素之间具有一定的顺序关系。
  • 3.线性表的长度与空表

  • 线性表的长度由元素的个数 n 决定(n ≥ 0),如果 n = 0 ,则称该线性表为“空表”。
  • 4.线性表(或线性结构)的特征

  • 存在唯一的一个数据元素被称为“第一个”。
  • 存在唯一的一个数据元素被称为“最后一个”。
  • 除第一个元素外,结构中的每个数据元素都有且只有一个前驱。
  • 除最后一个元素外,结构中的每个数据元素都有且只有一个后继。

学习更多嵌入式电子知识,C语言编程技术,欢迎抖音扫码关注

二.线性表之顺序表实现

1.项目结构以及初始代码

初始代码

main.c

#include <stdio.h>


int main(int argc, char** argv)
{


        return 0;
}

SeqList.h

#ifndef __SEQLIST_H__
#define __SEQLIST_H__

#include <stdio.h>

#define SEQLIST_INIT_SIZE 8 // 顺序表初始大小

typedef int ElemType;

typedef struct SeqList
{
    ElemType* base;// 指向顺序表空间
    int capacity;// 顺序表容量
    int size;// 顺序表长度(元素个数)
}SeqList;





#endif // !__SEQLIST_H__

SeqList.c

#include "SeqList.h"

2.顺序表初始化

SeqList.h

#ifndef __SEQLIST_H__
#define __SEQLIST_H__

#include <stdio.h>
#include <malloc.h>
#include <assert.h>

#define SEQLIST_INIT_SIZE 8 // 顺序表初始大小

typedef int ElemType;

typedef struct SeqList
{
    ElemType* base;// 指向顺序表空间
    int capacity;// 顺序表容量
    int size;// 顺序表长度(元素个数)
}SeqList;


void InitSeqList(SeqList* list);


#endif // !__SEQLIST_H__

main.c

#include <stdio.h>
#include "SeqList.h"

int main(int argc, char** argv)
{
    SeqList mylist;
    
    InitSeqList(&mylist);
    
    return 0;
}

SeqList.c

#include "SeqList.h"

void InitSeqList(SeqList* list)
{
    list->base = (ElemType*)malloc(sizeof(ElemType) * SEQLIST_INIT_SIZE);
    assert(list->base != NULL);
    list->capacity = SEQLIST_INIT_SIZE;
    list->size = 0;
}

3.顺序表操作代码框架

main.c

#include <stdio.h>
#include "SeqList.h"

int main(int argc, char** argv)
{
    SeqList mylist;

        InitSeqList(&mylist);


    // 顺序表操作的选择
    int select = 1;
    while (select)
    {
        printf("*********************************************\n");
        printf("* [1]  push_back         [2]  push_front    *\n");
        printf("* [3]  show_list         [4]  pop_back      *\n");
        printf("* [5]  pop_front         [6]  insert_pos    *\n");
        printf("* [7]  find              [8]  length        *\n");
        printf("* [9]  delete_pos        [10]  delete_val    *\n");
        printf("* [11] sort              [12] reverse       *\n");
        printf("* [13] clear             [14] destroy       *\n");
        printf("* [0]  quit_system                          *\n");
        printf("*********************************************\n");
        printf("请选择:>");
        scanf("%d", &select);

        if (select == 0)
        {
            break;
        }
        switch (select)
        {
        case 1:
        {
            break;
        }
        case 2:
        {
            break;
        }
        case 11:
        {
            break;
        }
        default:
        {
            printf("输入的选择错误,请重新输入!\n");
            break;
        }
        }
    }

    return 0;
}

注意:在visual studio2022中,使用scanf()函数获取输入,然后运行项目会报错:

解决方式:

重新运行项目,就不会报错了。

如果你喜欢这篇文章,别忘了收藏点赞关注,支持我们为您带来更多精彩内容!❤️🎉

动动手指,做起来吧! 👨‍💻👩‍💻,

后面我们还将一起讨论学习:序表尾部插入数据并显示顺序表头部插入数据顺序表尾部删除数据顺序表头部删除数据顺序表指定位置插入数据顺序表中查找指定的数据是否存在顺序表的长度顺序表按位置删除数据顺序表按值删除数据。。。。。。等等!

;