数据结构——考研笔记(二)线性表的定义和线性表之顺序表
文章目录
- 二、线性表
- 2.1 定义、基本操作
- 2.1.1 知识总览
- 2.1.2 线性表的定义
- 2.1.3 线性表的基本操作
- 2.1.4 知识回顾与重要考点
- 2.2 顺序表
- 2.2.1 知识总览
- 2.2.2 顺序表的定义
- 2.2.3 顺序表的实现——静态分配
- 2.2.4 顺序表的实现——动态分配
- 2.2.5 知识回顾与重要考点
- 2.2.6 顺序表的插入和删除
- 2.2.6.1 插入
- 2.2.6.2 插入操作的时间复杂度
- 2.2.6.3 删除
- 2.2.6.4 删除操作的时间复杂度
- 2.2.6.5 知识回顾与重要考点
- 2.2.7 顺序表的查找
- 2.2.7.1 按位查找
- 2.2.7.2 按值查找
- 2.2.7.3 知识回顾与重要考点
二、线性表
2.1 定义、基本操作
2.1.1 知识总览
- 线性表:
- 定义(逻辑结构)
- 基本操作(运算)
2.1.2 线性表的定义
线性表:线性表是具有相同数据类型的n(n$>=$0)个数据元素的有限序列,其中n为表长,当n=0时线性表是一个空表。若用L命名线性表,则其一般表示为
以下是几个概念
- ai是线性表中的“第i个”元素线性表中的位序
- a1是表头元素;an是表尾元素
- 除第一个元素外,每个元素有且仅有一个直接前驱;除最后一个元素外,每个元素有且仅有一个直接后继
2.1.3 线性表的基本操作
- InitList(&L):初始化表。构造一个空的线性表L,分配内存空间。
- DestoryList(&L):销毁操作。销毁线性表,并释放线性表L所占用的内存空间
- ListInsert(&L,i,e):插入操作。在表L中的第i个位置上插入指定元素e
- ListDelete(&L,i,&e):删除操作。删除表L中第i个位置的元素,并用e返回删除元素的值
- LocateElem(L,e):按值查找操作。在表L中查找具有给定关键字值的元素。
- GetElem(L,i):按位查找操作。获取表L中第i个位置的元素的值。
其他常用操作
- Length(L):求表长。返回线性表L的长度,即L中数据元素的个数。
- PrintList(L):输出操作。按前后顺序输出线性表L的所有元素值。
- Empty(L):判空操作。若L位空表,则返回true,否则返回false。
Tips:
- 对数据的操作(记忆思路)——创销、增删改查
- C语言函数的定义—— <返回值类型> 函数名(<参数1类型>参数1,<参数2类型>参数2,……)
- 实际开发中,可根据实际需求定义其他的基本操作
- 函数名和参数的形式、命名都可改变(命名要有可读性)
- 什么时候要传入“&”——对参数的修改结果需要“带回来”
为什么要实现对数据结构的基本操作》
- 团队合作编程,你定义的数据结构要让别人能够很方便的使用(封装)
- 将常用的操作/运算封装成函数,避免重复工作,降低出错风险
2.1.4 知识回顾与重要考点
2.2 顺序表
2.2.1 知识总览
2.2.2 顺序表的定义
顺序表:用顺序存储的方式实现线性表顺序存储。把逻辑上相邻的元素存储在物理位置上也相邻的存储单元中,元素之间的关系由存储单元的邻接关系来体现。
2.2.3 顺序表的实现——静态分配
#define MaxSize 10 //定义最大长度
typeof struct{ElemType data[MaxSize]; //用静态的“数组”存放数据元素int length; //顺序表的当前长度
}SqList; //顺序表的类型定义(静态分配方式)
上述代码中给各个数据元素分配连续的存储空间,大小位MaxSize*sizeof(ElemType)
-
代码实现
#include <stdio.h> #define MaxSize 10 //定义最大长度typedef struct {int data[MaxSize]; //用静态的“数组”存放数据元素int length; //顺序表的当前长度 }SqList; //顺序表的类型定义//基本操作——初始化一个顺序表 void InitList(SqList& L) {for (int i = 0; i < MaxSize; i++)L.data[i] = 0; //将所有数据元素设置位默认初始值L.length = 0; //顺序表初始长度为0 }int main() {SqList L; //声明一个顺序表InitList(L);//初始化顺序表//……未完待续,后续操作return 0; }
如果“数组”存满了怎么办?
可以放弃治疗,顺序表的表长刚开始确定后就无法更改(存储空间是静态的)
思考:如果刚开始就声明一个很大的内存空间呢?存在什么问题?
2.2.4 顺序表的实现——动态分配
Key:动态申请和释放内存空间
C —— malloc、free函数
malloc函数返回一个指针,需要强制转型为你定义数据元素类型指针
eg:L.data = (ElemType *)malloc(sizeof(ElemType)*InitSize)
表示要申请的一整片连续的内存空间
C++ —— new、delete关键字
- 代码实现
#include <stdlib.h>
#define InitSize 10 //默认的最大长度typedef struct {int* data; //指示动态分配数组的指针int MaxSize; //顺序表的最大容量int length; //顺序表的当前长度
}SeqList;void InitList(SeqList& L) {//用malloc函数申请一片连续的内存空间L.data = (int*)malloc(InitSize * sizeof(int));L.length = 0;L.MaxSize = InitSize;
}//增加动态数组的长度
void IncreaseSize(SeqList& L, int len) {int* p = L.data;L.data = (int*)malloc((L.MaxSize + len) * sizeof(int));for (int i = 0; i < L.length; i++) {L.data[i] = p[i]; //将数据复制到新区域}L.MaxSize = L.MaxSize + len; //顺序表最大长度增加lenfree(p); //释放原来的内存空间
}int main() {SeqList L; //声明一个顺序表InitList(L); //初始化顺序表//……往顺序表中随便插入几个元素……IncreaseSize(L, 5);return 0;
}
顺序表的特点:
- 随机访问,即可以在O(1)时间内找到第i个元素。(代码实现:data[i-1])
- 存储密度高,每个节点只存储数据元素。
- 拓展容量不方便(即便采用动态分配的方式实现。拓展长度的时间复杂度也比较高)
- 插入、删除操作不方便,需要移动大量元素。
2.2.5 知识回顾与重要考点
2.2.6 顺序表的插入和删除
2.2.6.1 插入
ListInsert(&L,i,e):插入操作。在表L中的第i个位置插入指定元素e。
- 代码实现
#include <stdio.h>
#define MaxSize 10 //定义最大长度typedef struct {int data[MaxSize]; //用静态的“数组”存放数据元素int length; //顺序表的当前长度
}SqList; //顺序表的类型定义//基本操作——初始化一个顺序表
void InitList(SqList& L) {for (int i = 0; i < MaxSize; i++)L.data[i] = 0; //将所有数据元素设置位默认初始值L.length = 0; //顺序表初始长度为0
}
//插入
bool ListInsert(SqList& L, int i, int e) {if (i<1 || i>L.length + 1) //判断i的范围是否有效return false;if (L.length >= MaxSize) //当前存储空间已满,不能插入return false;for (int j = L.length; j >= i; j--) {L.data[j] = L.data[j - 1]; //将第i个元素及之后的元素后移}L.data[i - 1] = e; //在位置i出放入eL.length++; //长度加1return true;
}int main() {SqList L; //声明一个顺序表InitList(L);//初始化顺序表//……此处省略一些代码,插入几个元素ListInsert(L, 3, 3);printf("data[2]=%d", L.data[2]);return 0;
}
2.2.6.2 插入操作的时间复杂度
2.2.6.3 删除
ListDelete(&L,i,&e):删除操作。删除表L中第i个位置的元素,并用e返回删除元素的值。
- 代码实现
#include <stdio.h>
#define MaxSize 10 //定义最大长度typedef struct {int data[MaxSize]; //用静态的“数组”存放数据元素int length; //顺序表的当前长度
}SqList; //顺序表的类型定义//基本操作——初始化一个顺序表
void InitList(SqList& L) {for (int i = 0; i < MaxSize; i++)L.data[i] = 0; //将所有数据元素设置位默认初始值L.length = 0; //顺序表初始长度为0
}
//插入
bool ListInsert(SqList& L, int i, int e) {if (i<1 || i>L.length + 1) //判断i的范围是否有效return false;if (L.length >= MaxSize) //当前存储空间已满,不能插入return false;for (int j = L.length; j >= i; j--) {L.data[j] = L.data[j - 1]; //将第i个元素及之后的元素后移}L.data[i - 1] = e; //在位置i出放入eL.length++; //长度加1return true;
}
//删除
bool ListDelete(SqList& L, int i, int& e) {if (i<1 || i>L.length) //判断i的范围是否有效return false;e = L.data[i - 1]; //将被删除的元素赋值给efor (int j = i; j < L.length; j++) {L.data[j - 1] = L.data[j]; //将第i个位置后的元素前移}L.length--; //线性表长度减1return true;
}
int main() {SqList L; //声明一个顺序表InitList(L);//初始化顺序表//……此处省略一些代码,插入几个元素ListInsert(L, 3, 3);int e = -1; //用变量e把删除的元素“带回来”if (ListDelete(L, 3, e))printf("已删除第3个元素,删除元素为=%d\n", e);elseprintf("位序i不合法,删除失败\n");return 0;
}
2.2.6.4 删除操作的时间复杂度
2.2.6.5 知识回顾与重要考点
2.2.7 顺序表的查找
2.2.7.1 按位查找
- 静态分配实现按位查找
- 动态分配实现按位查找
- 按位查找的时间复杂度
2.2.7.2 按值查找
LocateElem(L,e):按值查找操作。在表L中查找具有给定关键字值的元素。
注意:数组下标为i的元素值等于e,返回其位序i+1
- 代码实现
#include <stdio.h>
#define MaxSize 10 //定义最大长度typedef struct {int data[MaxSize]; //用静态的“数组”存放数据元素int length; //顺序表的当前长度
}SqList; //顺序表的类型定义//基本操作——初始化一个顺序表
void InitList(SqList& L) {for (int i = 0; i < MaxSize; i++)L.data[i] = 0; //将所有数据元素设置位默认初始值L.length = 0; //顺序表初始长度为0
}
//插入
bool ListInsert(SqList& L, int i, int e) {if (i<1 || i>L.length + 1) //判断i的范围是否有效return false;if (L.length >= MaxSize) //当前存储空间已满,不能插入return false;for (int j = L.length; j >= i; j--) {L.data[j] = L.data[j - 1]; //将第i个元素及之后的元素后移}L.data[i - 1] = e; //在位置i出放入eL.length++; //长度加1return true;
}
//删除
bool ListDelete(SqList& L, int i, int& e) {if (i<1 || i>L.length) //判断i的范围是否有效return false;e = L.data[i - 1]; //将被删除的元素赋值给efor (int j = i; j < L.length; j++) {L.data[j - 1] = L.data[j]; //将第i个位置后的元素前移}L.length--; //线性表长度减1return true;
}
//在顺序表L中查找第一个元素值等于e的元素,并返回其位序
int LocateElem(SqList L, int e) {for (int i = 0; i < L.length; i++) {if (L.data[i] == e)return i + 1;}return 0;
}
int main() {SqList L; //声明一个顺序表InitList(L);//初始化顺序表//……此处省略一些代码,插入几个元素ListInsert(L, 3, 3);int i = LocateElem(L, 3);printf("位序为%d", i);return 0;
}
- 按值查找的时间复杂度
2.2.7.3 知识回顾与重要考点
相关文章:

数据结构——考研笔记(二)线性表的定义和线性表之顺序表
文章目录 二、线性表2.1 定义、基本操作2.1.1 知识总览2.1.2 线性表的定义2.1.3 线性表的基本操作2.1.4 知识回顾与重要考点 2.2 顺序表2.2.1 知识总览2.2.2 顺序表的定义2.2.3 顺序表的实现——静态分配2.2.4 顺序表的实现——动态分配2.2.5 知识回顾与重要考点2.2.6 顺序表的…...

quota使用
一、检查系统是否支持 grep CONFIG_QUOTA /boot/config* CONFIG_QUOTAy CONFIG_QUOTA_NETLINK_INTERFACEy # CONFIG_QUOTA_DEBUG is not set CONFIG_QUOTA_TREEy CONFIG_QUOTACTLy CONFIG_QUOTACTL_COMPATy二、安装 yum install -y quota三、配置 3.1 创建磁盘 格式一定要 …...

解决fidder小黑怪倒出JMeter文件缺失域名、请求头
解决fidder小黑怪倒出JMeter文件缺失域名、请求头 1、目录结构: 2、代码 coding:utf-8 Software:PyCharm Time:2024/7/10 14:02 Author:Dr.zxyimport zipfile import os import xml.etree.ElementTree as ET import re#定义信息头 headers_to_extract [Host, Conn…...

智慧城市的神经网络:Transformer模型在智能城市构建中的应用
智慧城市的神经网络:Transformer模型在智能城市构建中的应用 随着城市化的快速发展,智能城市的概念应运而生,旨在通过先进的信息技术提升城市管理效率和居民生活质量。Transformer模型,作为人工智能领域的一颗新星,其…...

产品经理-研发流程-敏捷开发-迭代-需求评审及产品规划(15)
敏捷开发是以用户的需求进化为核心,采用迭代、循序渐进的方法进行软件开发。 通俗来说,敏捷开发是一个软件开发流程,是一个采用了迭代方法的开发流程 简单来说,迭代就是把一个大产品拆分出一些最小的实现单位。完成不同的迭代就最…...

Ansible 安装及使用说明
方案1. 直接下载 源码包到本地后安装 ansible 下载地址:https://releases.ansible.com/ansible/ ansible社区: https://github.com/ansible/ansible 下载地址:GitHub - ansible/ansible at v2.9.0 方案2. 以腾讯的yum源说明:腾讯云文档…...

MyBatisPlus实现增删改查
文章目录 MyBatisPlus实现增删改查基本操作分页查询配置分页插件 MyBatisPlus实现增删改查 实体类GkUser package com.geekmice.springbootselfexercise.entity;import com.baomidou.mybatisplus.annotation.IdType; import com.baomidou.mybatisplus.annotation.TableField;…...

【Rust】——不安全Rust
💻博主现有专栏: C51单片机(STC89C516),c语言,c,离散数学,算法设计与分析,数据结构,Python,Java基础,MySQL,linux…...

使机器人在执行任务时更加稳定
为了使机器人在执行任务时更加稳定,调整参数时需要考虑多个因素,如步态、速度、角度等。这些参数的调整需要基于实际环境、任务需求和机器人自身的物理特性。以下是一些具体的调整建议: 1. 调整步态和步高 gait_type3; step_height0.03;步态…...

FFmpeg学习(五)-- libswresample使用说明及函数介绍
libswresample Audio合成和重采样 libswresample库用来进行audio数据的合成和重采样操作。调用流程: 调用 swr_alloc 创建SwrContext结构体。设置SwrContext参数,有两种方法: 调用av_opt_set_xx函数逐项设置参数;swr_alloc_set_…...

车载视频监控管理方案:无人驾驶出租车安全出行的保障
近日,无人驾驶出租车“萝卜快跑”在武汉开放载人测试成为热门话题。随着科技的飞速发展,无人驾驶技术已逐渐从概念走向现实,特别是在出租车行业中,无人驾驶出租车的推出将为公众提供更为安全、便捷、高效的出行服务。 视频监控技…...

05STM32EXIT外部中断中断系统
STM32EXIT外部中断&中断系统 中断系统中断触发条件:中断处理流程和用途: STM32中断NVIC嵌套中断向量控制器基本结构NVIC基本结构NVIC优先级分组EXTI简介EXTI基本结构AFIO复用IO口EXTI内部框图旋转编码器简介硬件电路外设手册里的介绍NVIC中断使能寄存…...

MetaGPT和LangGraph对比
MetaGPT和LangGraph是两个不同的AI Agent框架,各有其特点和优势:MetaGPT: MetaGPT是一个多Agent协作框架,模拟软件公司的运作方式。它包含多个角色如产品经理、架构师、项目经理和工程师,每个角色都有特定的职责。MetaGPT采用对话模式&#…...

基于SpringBoot+Hadoop+python的物品租赁系统(带1w+文档)
基于SpringBootHadooppython的物品租赁系统(带1w文档) 基于SpringBootHadooppython的物品租赁系统(带1w文档) 物品租赁系统是电子、信息技术相结合,是一种必然的发展趋势。以互联网为基础,以服务于广大用户为目的,发展整体优势,扩…...

关于 RK3588刷镜像升级镜像”没有发现设备“ 的解决方法
若该文为原创文章,转载请注明原文出处 本文章博客地址:https://hpzwl.blog.csdn.net/article/details/140287339 长沙红胖子Qt(长沙创微智科)博文大全:开发技术集合(包含Qt实用技术、树莓派、三维、OpenCV…...

docker 上传镜像到hub仓库
要将 Docker 镜像上传到 Docker Hub,你需要按照以下步骤操作: 登录 Docker Hub 首先,你需要登录到 Docker Hub。打开终端并运行以下命令:docker login系统会提示你输入 Docker Hub 的用户名和密码。 如果密码忘记可以token登录&a…...

查询(q_proj)、键(k_proj)和值(v_proj)投影具体含义
查询(q_proj)、键(k_proj)和值(v_proj)投影,这些投影是自注意力机制的核心组件,特别是在Transformer架构中。 让我们通过一个简化的例子来说明: import numpy as np# 假设输入维度是4,注意力头数是2 input_dim 4 num_heads 2 …...

超详细版阿里云控制台环境配置+数据库配置
目录 一、登录阿里云控制台二、xshell建立远程连接1.安装xshell2.查看公网IP3.新建会话重置密码 三、搭建环境1.安装宝塔面板2.打开宝塔面板 四、安装配置MySQL1.安装2.放行端口号3.新建数据库4.测试连接数据库 一、登录阿里云控制台 登录阿里云控制台,找到实例&am…...

Linux:Linux网络总结(附下载链接)
文章目录 下载链接网络问题综合问题访问一个网页的全过程?WebSocket HTTPHTTP基本概念GET与POSTHTTP特性HTTP缓存技术HTTP的演变HTTP1.1 优化 HTTPSHTTP与HTTPS有哪些区别?HTTPS解决了HTTP的哪些问题?HTTPS如何解决的?HTTPS是如何…...

Cxx Primer-CP-2
开篇第一句话足见作者的高屋建瓴:类型决定程序中数据和操作的意义。随后列举了简单语句i i j;的意义取决于i和j的类型。若它们都是整形,则为通常的算术意义。若它们都为字符串型,则为进行拼接操作。若为用户自定义的class类型,则…...

OpenCV距离变换函数distanceTransform的使用
操作系统:ubuntu22.04OpenCV版本:OpenCV4.9IDE:Visual Studio Code编程语言:C11 功能描述 distanceTransform是OpenCV库中的一个非常有用的函数,主要用于计算图像中每个像素到最近的背景(通常是非零像素到零像素&…...

Service Mesh 是一种用于处理服务间通信的基础设施层
Service Mesh 是一种用于处理服务间通信的基础设施层,它通常与微服务架构一起使用,以提供诸如服务发现、负载均衡、熔断、监控、追踪和安全性等功能。Service Mesh 的一个流行实现是 Istio,它基于 Envoy 代理和 Kubernetes。 然而࿰…...

QML界面控件加载与显示顺序
一、QML界面控件加载顺序 QML在界面加载时的顺序和我们认知的有很大的不同,有时候会对我们获取参数以及界面实现造成很大的困扰 1、加载顺序 import QtQuick 2.12 import QtQml 2.12 import QtQuick.Window 2.12 import QtQuick.VirtualKeyboard 2.4Window {id: …...

C++从入门到起飞之——缺省参数/函数重载/引用全方位剖析!
目录 1.缺省参数 2. 函数重载 3.引⽤ 3.1 引⽤的概念和定义 3.2 引⽤的特性 3.3 引⽤的使⽤ 3.4 const引⽤ 3.5 指针和引⽤的关系 4.完结散花 个人主页:秋风起,再归来~ C从入门到起飞 个人格言:悟已往之不谏…...

tkinter-TinUI-xml实战(12)pip可视化管理器
引言 pip命令行工具在平常使用方面确实足够简单,本项目只是作为TinUI多界面开发的示例。 当然,总有人想用GUI版pip,实际上也有。不过现在,我们就来手搓一个基于python和TinUI(tkinter)的pip可视化管理器。…...

Java中标识符和关键字
1.标识符 public class HelloWorld{public static void main(String[] args){System.out.println("Hello,world");} }上述代码中在public class 后面的HelloWorld称为类名,main称为方法名,也可以将其称为标识符,即:在程…...

电子版pdf格式标书怎么加盖公章?
电子版PDF格式标书加盖公章的方法有多种,以下是一些常用的步骤和技巧: 一、手动插入图片法 打开PDF文档:首先,确保你已经安装了支持PDF编辑的软件,如Adobe Acrobat Reader DC、Foxit PDF Editor等。选择插入图片&…...

【开放集目标检测】Grounding DINO
一、引言 论文: Grounding DINO: Grounding DINO: Marrying DINO with Grounded Pre-Training for Open-Set Object Detection 作者: IDEA 代码: Grounding DINO 注意: 该算法是在Swin Transformer、Deformable DETR、DINO基础上…...

东莞酷得 PMS134应广8位OTP单片机
1、特性 通用 OTP 系列 不建议使用于 AC 阻容降压供电或有高 EFT 要求的应用。应广不对使用于此类应用而不达安规要求负责 工作温度范围:-20C~70C 1.2.系统特性 一个硬件 16位计数器 两个8位硬件 PWM生成器 三个11 位硬件 PWM生成器(PWMG0,PWMG1…...

[终端安全]-7 后量子密码算法
本文参考资料来源:NSA Releases Future Quantum-Resistant (QR) Algorithm Requirements for National Security Systems > National Security Agency/Central Security Service > Article Commercial National Security Algorithm Suite 2.0” (CNSA 2.0) C…...