• 数据结构-线性结构


    线性结构 包括队列、栈、链表

    线性表(linear list)是数据结构的一种,一个线性表是n个具有相同特性的数据元素的有限序列。数据元素是一个抽象的符号,其具体含义在不同的情况下一般不同。

    在稍复杂的线性表中,一个数据元素可由多个数据项组成,此种情况下常把数据元素称为记录,含有大量记录的线性表又称文件。

    线性表中的个数n定义为线性表的长度,n=0时称为空表。在非空表中每个数据元素都有一个确定的位置,如用ai表示数据元素,则i称为数据元素ai在线性表中的位序。

    线性表的相邻元素之间存在着序偶关系。如用(a1,…,ai-1,ai,ai+1,…,an)表示一个顺序表,则表中ai-1领先于aiai领先于ai+1,称ai-1是ai的直接前驱元素,ai+1是ai的直接后继元素。当i=1,2,…,n-1时,ai有且仅有一个直接后继,当i=2,3,…,n时,ai有且仅有一个直接前驱。

    特征

    1.集合中必存在唯一的一个“第一元素”。

    2.集合中必存在唯一的一个 “最后元素” 。

    3.除最后一个元素之外,均有 唯一的后继(后件)。

    4.除第一个元素之外,均有 唯一的前驱(前件)。

    基本操作

    1)MakeEmpty(L) 这是一个将L变为空表的方法

    2)Length(L) 返回表L的长度,即表中元素个数

    3)Get(L,i) 这是一个函数,函数值为L中位置i处的元素(1≤i≤n)

    4)Prior(L,i) 取i的前驱元素

    5)Next(L,i) 取i的后继元素

    6)Locate(L,x) 这是一个函数,函数值为元素x在L中的位置

    7)Insert(L,i,x)在表L的位置i处插入元素x,将原占据位置i的元素及后面的元素都向后推一个位置

    8)Delete(L,p) 从表L中删除位置p处的元素

    9)IsEmpty(L) 如果表L为空表(长度为0)则返回true,否则返回false

    10)Clear(L)清除所有元素

    11)Init(L)同第一个,初始化线性表为空

    12)Traverse(L)遍历输出所有元素

    13)Find(L,x)查找并返回元素

    14)Update(L,x)修改元素

    15)Sort(L)对所有元素重新按给定的条件排序

    16) strstr(string1,string2)用于字符数组的求string1中出现string2的首地址

    存储结构

    线性表主要由顺序表示或链式表示。在实际应用中,常以队列字符串等特殊形式使用。

    顺序表示指的是用一组地址连续的存储单元依次存储线性表的数据元素,称为线性表的顺序存储结构或顺序映像。它以“物理位置相邻”来表示线性表中数据元素间的逻辑关系,可随机存取表中任一元素。

    链式表示指的是用一组任意的存储单元存储线性表中的数据元素,称为线性表的链式存储结构。它的存储单元可以是连续的,也可以是不连续的。在表示数据元素之间的逻辑关系时,除了存储其本身的信息之外,还需存储一个指示其直接后继的信息(即直接后继的存储位置),这两部分信息组成数据元素的存储映像,称为结点(node)。它包括两个域;存储数据元素信息的域称为数据域;存储直接后继存储位置的域称为指针域。指针域中存储的信息称为指针或链

    结构特点

    1.均匀性:虽然不同数据表的数据元素可以是各种各样的,但对于同一线性表的各数据元素必定具有相同的数据类型和长度。

    2.有序性:各数据元素在线性表中的位置只取决于它们的序号,数据元素之前的相对位置是线性的,即存在唯一的“第一个“和“最后一个”的数据元素,除了第一个和最后一个外,其它元素前面均只有一个数据元素(直接前驱)和后面均只有一个数据元素(直接后继)。

     

  • 相关阅读:
    素数回文 ---- 有点暴力.....
    Manacher算法 , 实例 详解 . NYOJ 最长回文
    大数处理 详解 模版
    River Crossing 简单的动态规划 .
    hdu
    产生冠军 map 的 应用 .
    MySQL的数据库备份与恢复。
    rsync的相关使用,参数设置。
    centos与mac安装python虚拟环境 virtualenvwrapper
    CentOS7安装Python3.7
  • 原文地址:https://www.cnblogs.com/mamamia/p/7853128.html
Copyright © 2020-2023  润新知