一.线性表的定义和特点
-  
线性表的定义
 
- 线性表是一种数据结构,它包含了一系列具有相同特性的数据元素,数据元素之间存在着顺序关系。例如,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()函数获取输入,然后运行项目会报错:

解决方式:



重新运行项目,就不会报错了。
如果你喜欢这篇文章,别忘了收藏、点赞、关注,支持我们为您带来更多精彩内容!❤️🎉
动动手指,做起来吧! 👨💻👩💻,
后面我们还将一起讨论学习:顺序表尾部插入数据并显示,顺序表头部插入数据,顺序表尾部删除数据,顺序表头部删除数据,顺序表指定位置插入数据,顺序表中查找指定的数据是否存在,顺序表的长度,顺序表按位置删除数据,顺序表按值删除数据。。。。。。等等!



















