软考之路--数据结构之线性表

简介:         数据就是数值,也就是我们通过观察、实验或计算得出的结果。数据有很多种,最简单的就是数字。数据也可以是文字、图像、声音等。数据可以用于科学研究、设计、查证等。

        数据就是数值,也就是我们通过观察、实验或计算得出的结果。数据有很多种,最简单的就是数字。数据也可以是文字、图像、声音等。数据可以用于科学研究、设计、查证等。结构,组成整体的各部分的搭配和安排,两者完美结合在一起,我们这样需要重新认识她,对她重新审视与定义:数据结构是程序设计的重要理论和技术基础,她所讨论的内容和技术,对从事软件项目的开发有重要作用,通过学习数据结构,我们学会从问题出发,分析和研究计算机加工的数据的特性,以便为应用所设计的数据悬着适当的逻辑结构、存储结构及其相应的操作方法,为提高应用计算机解决问题的效率服务。

        学习希赛视频有一段日子了,这一段日子夹杂的自考和等级考,夸张点儿来说,有过欢笑,也有过泪水,欢笑的是昨天等级考试抽到的两道大题都是原题,泪水的是,第二题有一个空少些了一个return,又想起那句话,总是要等到考试的时候,才知道该念的书没有念,大题一共六十分,如果按往年的算分制度,需要占百分之六十,也就是说六十分要考三十六分才算合格,可是我满打满算,最后一题只能拿到三十四分,可是后话是,过了我开心,过不了更开心,可以再学一遍C++`(*∩_∩*)′,今天小编主要来讲解一下数据结构的数据表,首先,我们来看一下基本数据结构的一张图:

        

       了解了基本数据结构,进入到我们今天的主题线性表,该博文主要围绕以下内容展开进行阐述:

        

        一、线性表

        概念:线性表是最简单,最基本,也是最常用的一种线性结构,她有两种存储存储方法,顺序存储和链式存储,主要的基本操作是插入,删除和查找等。

   分类:线性表分为顺序表和链表,其中链表又分为单链表、循环链表和双链表,依次进行分析。

    顺序表,如下图所示:

    

    顺序结构:顺序结构是最简单的程序结构,也是最常用的程序结构,只要按照解决问题的顺序写出相应的语句就行,它的执行顺序是自上而下,依次执行。举个简单的例子,a = 3,b = 5,现交换a,b的值,这个问题就好像交换两个杯子水,这当然要用到第三个杯子,假如第三个杯子是c,那么正确的程序为: c = a; a = b; b = c; 执行结果是a = 5,b = c = 3。

    链表,如下图所示:

    

    链表:链表是一种物理存储单元上非连续、非顺序的存储结构,数据元素的逻辑顺序是通过链表中的指针链接次序实现的。链表由一系列结点(链表中每一个元素称为结点)组成,结点可以在运行时动态生成。每个结点包括两个部分:一个是存储数据元素的数据域,另一个是存储下一个结点地址的指针域。 相比于线性表顺序结构,操作复杂。

   链表的类别:单链表、循环链表、双链表。如下图所示:

   

    数据域:存放数据;指针域:存放指向下一个节点的地址;循环链表:最后一个节点她的下一个节点是头节点。

双链表:有两个指针域,从两个不同的方向把链表链接起来。双链表可以从两个方向移动,单链表朝单一的方向移动,双链表的灵活度优于单链表。双链表的开支会大一些,因为她有两个指针域。
    单双链表的删除和插入单链表的删除:结点的删除,删除a2,方法:把a1的指针域直接指向a3,跳过a2,就可以了,a2就从链表中删除了,还有一个工作需要把a2释放掉。把要删除的前序结点,前序结点的next域指向她的后序结点。单链表的插入:删除结点是把前序指向后序,那么插入一个结点就是一个逆向的过程,把新的结点,从需要插入的位置,把她的前序结点next域指向新加入的结点,再把新加入的结点的next域指向下一个结点,就可以了。双链表的删除和插入:牵涉两个方面,从左至右列出来,从右至左列出来,并不是简单的一条链过去,一条链过来就完成的,我们需要把四个步骤都写出来,把两个操作的第一步都先完成,完成之后,接着第二步。
   顺序表PK链表

    

    

    二、队列

    概念:队列是一种特殊的线性表,它只允许在表的前端(front)进行删除操作,而在表的后端(rear)进行插入操作。进行插入操作的端称为队尾,进行删除操作的端称为队头。队列中没有元素时,称为空队列。比如,去食堂排队,排头最先买到菜,后面来的同学排的队尾;进车站时,安检行李,先进去的最先出来,后进去的后出来。

    分类:顺序队列和循坏队列;队列是一种特殊的线性表,特殊之处在于它只允许在表的前端(front)进行删除操作,而在表的后端(rear)进行插入操作,和栈一样,队列是一种操作受限制的线性表。进行插入操作的端称为队尾,进行删除操作的端称为队头。队列中没有元素时,称为空队列。在队列这种数据结构中,最先插入的元素将是最先被删除的元素;反之最后插入的元素将是最后被删除的元素,因此队列又称为“先进先出”(FIFO—first in first out)的线性表。如下图:

   顺序队列:

    

    循环队列:

       

      ps:“对”字写错了,大家不要见笑哦。

      三、栈

      栈:并不是一个实实在在存在的东西,是逻辑上的一个概念,一种思想,一种理念,她不像链式存储和顺序存储一个一个结点,很有规律,她是在顺序存储和链式存储之上的,是逻辑的概念,栈既可以用链式结构来实现,也可以用顺序结构来实现--即数组。定义一个规则,先进后出即可。如下:

   

   题目如果问你:按0,1,2,3,4入栈,出栈顺序有哪些呢,是不是只有4,3,2,1,0呢?答:错误,也可能按照0,1,2,3,4,出栈,即0入栈,马上出栈,然后1入栈,马上出栈……

   小编寄语:线性表(亦作顺序表)是最基本、最简单、也是最常用的一种数据结构。线性表中数据元素之间的关系是一对一的关系,即除了第一个和最后一个数据元素之外,其它数据元素都是首尾相接的。线性表的逻辑结构简单,便于实现和操作。因此,线性表这种数据结构在实际应用中是广泛采用的一种数据结构。其中栈和队列是一种特殊的线性表,软考之路,未完待续......

       

目录
相关文章
|
16天前
|
存储 算法 测试技术
【C++数据结构——线性表】求集合的并、交和差运算(头歌实践教学平台习题)【合集】
本任务要求编写程序求两个集合的并集、交集和差集。主要内容包括: 1. **单链表表示集合**:使用单链表存储集合元素,确保元素唯一且无序。 2. **求并集**:遍历两个集合,将所有不同元素加入新链表。 3. **求交集**:遍历集合A,检查元素是否在集合B中存在,若存在则加入结果链表。 4. **求差集**:遍历集合A,检查元素是否不在集合B中,若满足条件则加入结果链表。 通过C++代码实现上述操作,并提供测试用例验证结果。测试输入为两个集合的元素,输出为有序集合A、B,以及它们的并集、交集和差集。 示例测试输入: ``` a c e f a b d e h i ``` 预期输出:
39 7
|
16天前
|
机器学习/深度学习 存储 C++
【C++数据结构——线性表】单链表的基本运算(头歌实践教学平台习题)【合集】
本内容介绍了单链表的基本运算任务,涵盖线性表的基本概念、初始化、销毁、判定是否为空表、求长度、输出、求元素值、按元素值查找、插入和删除数据元素等操作。通过C++代码示例详细解释了顺序表和链表的实现方法,并提供了测试说明、通 - **任务描述**:实现单链表的基本运算。 - **相关知识**:包括线性表的概念、初始化、销毁、判断空表、求长度、输出、求元素值、查找、插入和删除等操作。 - **测试说明**:平台会对你编写的代码进行测试,提供测试输入和预期输出。 - **通关代码**:给出了完整的C++代码实现。 - **测试结果**:展示了测试通过后的预期输出结果。 开始你的任务吧,祝你成功!
31 5
|
16天前
|
机器学习/深度学习 存储 C++
【C++数据结构——线性表】顺序表的基本运算(头歌实践教学平台习题)【合集】
本文档介绍了线性表的基本运算任务,涵盖顺序表和链表的初始化、销毁、判定是否为空、求长度、输出、查找元素、插入和删除元素等内容。通过C++代码示例详细展示了每一步骤的具体实现方法,并提供了测试说明和通关代码。 主要内容包括: - **任务描述**:实现顺序表的基本运算。 - **相关知识**:介绍线性表的基本概念及操作,如初始化、销毁、判定是否为空表等。 - **具体操作**:详述顺序表和链表的初始化、求长度、输出、查找、插入和删除元素的方法,并附有代码示例。 - **测试说明**:提供测试输入和预期输出,确保代码正确性。 - **通关代码**:给出完整的C++代码实现,帮助完成任务。 文档
31 5
|
7月前
|
存储 C语言
数据结构中的线性表链式存储介绍及其基本操作
链式存储是线性表的一种重要存储方式,它通过节点和指针的结构,实现了灵活的动态存储管理。本文介绍了单向链表的基本操作,并提供了相应的C语言代码示例。理解和掌握链表的操作对学习和应用数据结构具有重要意义。希望这篇博客能帮助你更好地理解线性表的链式存储。
163 2
|
3月前
|
存储 Java
数据结构第二篇【关于java线性表(顺序表)的基本操作】
数据结构第二篇【关于java线性表(顺序表)的基本操作】
55 6
|
3月前
|
存储
【数据结构】线性表和顺序表
【数据结构】线性表和顺序表
35 1
|
2月前
|
算法 安全 搜索推荐
2024重生之回溯数据结构与算法系列学习之王道第2.3章节之线性表精题汇总二(5)【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丢脸好嘛?】
IKU达人之数据结构与算法系列学习×单双链表精题详解、数据结构、C++、排序算法、java 、动态规划 你个小黑子;这都学不会;能不能不要给我家鸽鸽丢脸啊~除了会黑我家鸽鸽还会干嘛?!!!
|
7月前
|
算法
数据结构和算法学习记录——线性表之双向链表(上)-结点类型定义、初始化函数、创建新结点函数、尾插函数、打印函数、尾删函数
数据结构和算法学习记录——线性表之双向链表(上)-结点类型定义、初始化函数、创建新结点函数、尾插函数、打印函数、尾删函数
61 0
|
3月前
01(数据结构考研)线性表相关操作代码
01(数据结构考研)线性表相关操作代码
96 0
|
3月前
|
存储 C语言
数据结构之线性表的初始化及其操作
数据结构之线性表的初始化及其操作
58 0

热门文章

最新文章