什么是数据结构
线性表(linear list)
线性表是n个类型相同数据元素的有限序列,包括 线性链表 和 顺序表。
顺序存储结构:
把线性表的结点按逻辑顺序依次存放在一组地址连续的存储单元里。是一种随机存取的存储结构。顺序存储指内存地址是连续的,随机存取指访问时可以按下标随机访问,存储和存取是不一样的。如果是存储,则是指按顺序的,如果是存取,则是可以随机的,可以利用元素下标进行。数组就是顺序表的一种实现。栈,队列都是线性表的存储形式。这里暂时不提及
优点:无序为表示元素的逻辑关系增加存储空间
可以快速存取表中任意位置的元素
缺点:插入和删除需要移动大量元素
当线性表长度变化较大,难以确定存储空间的容量
造成存储空间的碎片
链式存储结构:
前面提到了顺序存储的不足。链式就解决了大部分问题。
用一组任意的存储单元来依次存放线性表的结点,这组存储单元不必依次存储,可以分布在内存的不同位置。通过指针来联系相邻节点。因此,链表中结点的逻辑次序和物理次序不一定相同。为了能正确表示结点间的逻辑关系,在存储每个结点值的同时,还必须存储指示其后继结点的地址。data域是数据域,用来存放结点的值。next是指针域(亦称链域),用来存放结点的直接后继的地址(或位置)。链表有很多实现,比如单链表,双链表,循环链表,静态链表。这里就不提及了。