python数据结构-顺序表

顺序表

        线性表的顺序表示指的是用一组地址连续的存储单元依次存储线性表的数据元素,这种表示也称作线性表的顺序存储结构或者顺序映像。通常,称这种存储结构的线性表为顺序表。其特点是,逻辑上相邻的数据元素,其物理次序也是相邻的。

顺序表的基本形式

python数据结构-顺序表_第1张图片

顺序表的两种基本实现方式

python数据结构-顺序表_第2张图片

        图a为一体式结构,存储表信息的单元与元素存储区以连续的方式安排在一块存储区里, 两部分数据的整体形成一个完整的顺序表对象。一体式结构整体性强,易于管理。但是由于数据元素存储区域是表对象的一部分,顺序表创建后,元素存储区就固定了。

        图b为分离式结构,表对象里只保存与整个表有关的信息(即容量和元素个数),实际数据元素存放在另一个独立的元素存储区里,通过链接与基本表对象关联。

python中的顺序表

        Python中的list和tuple两种类型采用了顺序表的实现技术,具有前面讨论的顺序表的所有性质。

        tuple是不可变类型,即不变的顺序表,因此不支持改变其内部状态的任何操作,而其他方面,则与list的性质类似。

Python标准类型list就是一种元素个数可变的线性表,可以加入和删除元素。

append()在队尾加入元素,时间复杂度为O(1)

pop()在队尾移动一个,时间复杂度为O(1)

pop(i)时间复杂度为O(n)

insert(i,item)插入操作,时间复杂度为O(n)

del()删除操作,时间复杂度为O(n)

你可能感兴趣的:(数据结构,python,链表)