当前位置: 首页 > article >正文

线性表代码实战

10.2 线性表的顺序表示原理解析

一、命名规范:

  1. 下划线命名法 list_insert
  2. 驼峰命名法 ListInsert(每个单词的首字母大写)

二、线性表的定义:

​ 由n(n>=0)个相同类型的元素组成的有序集合。

三、线性表特点:

  1. 表中元素的个数时有限的;
  2. 表中元素的数据类型都相同。意味着每一个元素占用相同大小的空间;
  3. 表中元素具有逻辑上的顺序性,在序列中各元素排序有其先后顺序。

==!!!==以上均描述的是线性表的逻辑结构,是独立于存储结构的

四、线性表的顺序表示(简称 顺序表)

1.顺序表的定义:

image-20230402215843165

2.优缺点:

image-20230402215910525

3.插入操作的伪代码:

image-20230402215927283

4.删除操作的伪代码:

image-20230402215940743

5.写代码时的注意事项:
  1. !!!定义、插入、删除操作一定要修改线性表长度呀!!!

  2. 插入和删除操作的i的合法范围是不一样的:

操作i的合法范围
插入【1,n+1】
删除【1,n】
#include <stdio.h>
#define Maxsize 50

typedef int ElemType;//让顺序表存储其他类型元素时,可以快速完成代码修改

// 顺序表的初始化
typedef struct{
    ElemType data[Maxsize];
    ElemType length;
}SqList;

// 插入操作
bool list_insert(SqList &l, int i, ElemType element){
    //判断插入位置是否合理
    if(i < 1 || i > l.length+1){
        return false;
    }
    //是否线性表的位置已经满了
    if(l.length == Maxsize){
        return false;
    }
    //插入元素
    for(int j = l.length; j >= i; j--){
        l.data[j] = l.data[j - 1];
    }
    l.data[i] = element;
    l.length++;
    return true;
}

// 输出线性表
void print_list(SqList l){
    for(int j = 0; j < l.length; j++){
        printf("%3d", l.data[j]);
    }
    printf("\n");
}

// 顺序表的删除操作,并打印出删除的元素
bool delete_list(SqList &l, int i, ElemType &element){
    //判断删除的位置是否合理
    if(i < 1 || i > l.length){
        return false;
    }
    //先把元素提取出来,赋值给element
    element = l.data[i - 1];
    //进行删除操作
    for(int j = i; j < l.length; j++){
        l.data[j - 1] = l.data[j];
    }
    l.length--;//顺序表长度的变化一定一定不能忘记了!!!!
    return true;
}

// 顺序表的查找操作,并打印出所查找元素的位置
bool select_list(SqList l, int &pos, ElemType element){
    for(int j = 0; j <l.length; j++){
        if(element == l.data[j]){
            pos = j + 1;
            return true;
        }
    }
    pos = 0;
    return false;
}

int main() {
    SqList l;//新建一个线性表
    l.data[0] = 0;//放置元素
    l.data[1] = 1;
    l.data[2] = 2;
    l.data[3] = 3;
    l.length = 4;//线性表的长度一定要记得初始化呀!!!
    print_list(l);
    int ret;
    ret = list_insert(l, 4, 7);
    if(ret){
        printf("insert succeed!!! congratulation\n");
    }else{
        printf("insert fail!!! come on");
    }
    printf("---------------------------\n");
    print_list(l);
    int del;//用来读取被删除的元素
    ret = delete_list(l,5,del);
    if(ret){
        print_list(l);
        printf("delete succeed!!! congratulation\n");
        printf("delete element = %d",del);
    }else{
        printf("delete fail!!! come on");
    }
    printf("---------------------------\n");
    print_list(l);
    int pos;//用来保存所查找元素的位置
    ret = select_list(l,pos,3);
    if(ret){
        print_list(l);
        printf("select succeed!!! congratulation\n");
        printf("pos element = %d",pos);
    }else{
        printf("select fail!!! come on");
    }
    return 0;
}

五、线性表的链式表示(简称,链表)

1.单链表结点的定义:

image-20230402220002858

2.头指针与头结点的区别:

image-20230402220017098

!!!注意:

1.头结点不是链表第一个结点,第一个结点指的是头结点后面的结点

2.头指针一定不为空,但是头结点不是必须的。

3.优缺点:

image-20230402220030047

4.插入操作:

image-20230402220041300

5.删除操作:

image-20230402220055317

6.按序号查找结点:

image-20230402220109038

7.按值查找结点:

image-20230402220119752


http://www.kler.cn/a/509151.html

相关文章:

  • 某国际大型超市电商销售数据分析和可视化
  • MyBatisPlus学习笔记
  • AI在SEO中的关键词优化策略探讨
  • CSS 样式 margin:0 auto; 详细解读
  • UDP报文格式
  • 《Keras 3 在 TPU 上的肺炎分类》
  • 开发完全开源的AI会议助手:提升会议效率
  • STM32的DMA作用
  • Ubuntu20.04安装mysql9.0.1,并且修改数据文件路径
  • 【C++】哈希表的使用
  • Solidity03 Solidity变量简述
  • SpringBoot的AOP-入门
  • nvm 管理nodejs,安装pnpm后报错,出现:pnpm不是内部或外部命令,也不是可运行的程序或批处理文件。
  • Plume :RWAfi 叙事引领者,全新加密时代的新蓝筹生态
  • 第4章 Kafka核心API——Kafka客户端操作
  • 深度学习常见术语解释
  • 计算机网络ENSP课设--三层架构企业网络
  • 后盾人JS -- JS数组挖掘(成年篇)
  • Mysql--实战篇--连接池(连接池原理,HikariCP、C3P0、Druid和DBCP等)
  • LLama 架构一览
  • QT的TCP通讯
  • PG 和 mysql 区别
  • 【JavaScript】基础极速笔记
  • 【MySQL】数据库约束和多表查询
  • Jenkins-Pipeline简述
  • 如何保证Bitmap数据在多个服务器间的一致性