列表和数组的定义
数组是什么?
数组(Array)是一种线性表数据结构。它用一组连续的内存,来存储一组具有相同类型的数据。
优点:数组地址是连续的会给我们查找数据提供了极大的方便,让我们很容易的就能根据下标找到你需要的数据,提高了查询效率
缺点:毕竟我们对数组的运用不只是查找数据,还有增加数据,插入数据,删除数据等一些操作;由于数组的特殊性,使得我们在进行这些操作的时候不能对其进行直接操作,还要重新开辟一个新的数组并使其长度增加来存放数据,这样的工作模式给我们带来了很大的不便,影响了效率
**用线性表存储的数据有两个特点:
形象地来看,线性表就是数据排成像一条线一样的结构,并且最多只有前和后两个方向。数组、链表队列、栈等都是线性表结构。
与其对立的概念是非线性表,如二叉树、堆等。在非线性表中,数据之间并不是简单的前后关系。
将列表当做堆栈使用
列表方法使得列表可以很方便的作为一个堆栈来使用,堆栈作为特定的数据结构,最先进入的元素最后一个被释放(后进先出)。用 append() 方法可以把一个元素添加到堆栈顶。用不指定索引的 pop() 方法可以把一个元素从堆栈顶释放出来
>>> stack = [3, 4, 5]
>>> stack.append(6)
>>> stack.append(7)
>>> stack
[3, 4, 5, 6, 7]
>>> stack.pop()
7
>>> stack
[3, 4, 5, 6]
>>> stack.pop()
6
>>> stack.pop()
5
>>> stack
[3, 4]
将列表当作队列使用
也可以把列表当做队列用,只是在队列里第一加入的元素,第一个取出来;但是拿列表用作这样的目的效率不高。在列表的最后添加或者弹出元素速度快,然而在列表里插入或者从头部弹出速度却不快(因为所有其他的元素都得一个一个地移动)。
相同点:
不同点:
import numpy as np
list1=[1,'a','index'] #list1是列表类型
list2 = np.array([1,2,3,4]) #list2是数组类型
print("list",list1,list1[0],'\n','array',list2,list2[0])
结果
打印结果:
list [1,'a','index'] 1
array [1 2 3 4] 1