python数据结构丨列表

本文的文字及图片来源于网络,仅供学习、交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理

以下文章来源于腾讯云,作者:端碗吹水

前言

python数据结构
  • 列表
  • 将列表当做堆栈使用
  • 将列表当作队列使用
  • 列表推导式
  • 嵌套列表解析
  • del 语句
  • 元组和序列
  • 集合
  • 字典
  • 遍历技巧
列表

Python中列表是可变的,这是它区别于字符串和元组的最重要的特点,一句话概括即:列表可以修改,而字符串和元组不能。

以下是 Python 中列表
>>> a = [66.25, 333, 333, 1, 1234.5]
>>> print(a.count(333), a.count(66.25), a.count('x'))
2 1 0
>>> a.insert(2, -1)
>>> a.append(333)
>>> a
[66.25, 333, -1, 333, 1, 1234.5, 333]
>>> a.index(333)
1
>>> a.remove(333)
>>> a
[66.25, -1, 333, 1, 1234.5, 333]
>>> a.reverse()
>>> a
[333, 1234.5, 1, 333, -1, 66.25]
>>> a.sort()
>>> a
[-1, 1, 66.25, 333, 333, 1234.5]

注意:类似 insert, remove 或 sort 等修改列表的方法没有返回值。

将列表当做堆栈使用

列表方法使得列表可以很方便的作为一个堆栈来使用,堆栈作为特定的数据结构,最先进入的元素最后一个被释放(后进先出)。用 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]

将列表当作队列使用

也可以把列表当做队列用,只是在队列里第一个加入的元素,第一个取出来(先进先出);需要通过deque模块把列表转换成队列,通过popleft函数来释放元素,但是拿列表用作这样的目的效率不高。在列表的最后添加或者弹出元素速度快,然而在列表里插入或者从头部弹出速度却不快(因为所有其他的元素都得一个一个地移动)。

>>> from collections import deque
>>> queue = deque(["Eric", "John", "Michael"])  # 把列表转换成队列模式
>>> queue.append("Terry")           # 向列表添末尾加元素
>>> queue.append("Graham")          
>>> queue.popleft()                 # 释放元素
'Eric'
>>> queue.popleft()                 
'John'
>>> queue                           
deque(['Michael', 'Terry', 'Graham'])

列表推导式

列表推导式提供了从序列创建列表的简单途径。通常应用程序将一些操作应用于某个序列的每个元素,用其获得的结果作为生成新列表的元素,或者根据确定的判定条件创建子序列。
每个列表推导式都在 for 之后跟一个表达式,然后有零到多个 for 或 if 子句。返回结果是一个根据表达从其后的 for 和 if 上下文环境中生成出来的列表。如果希望表达式推导出一个元组,就必须使用括号。
这里我们将列表中每个数值乘三,获得一个新的列表:

vec=[1,2,3]
list1=[x*3 for x in vec]  # 列表推导式

print(list1)
运行结果:
[3, 6, 9]

从以上示例可以得知,所谓推导式就是写在方括号里的一个混合表达式,这个表达式会返回出一个新的列表对象(如果使用的是方括号的话)

还可以生成二维列表:

vec=[1,2,3]
list1=[[x,x**3] for x in vec] # 在列表推导式里加多一个方括号就会生成二维列表

print(list1)

运行结果:

[[1, 1], [2, 8], [3, 27]]

还可以对序列里的每一个元素逐个调用某方法:

>>> freshfruit = ['  banana', '  loganberry ', 'passion fruit  ']
>>> [weapon.strip() for weapon in freshfruit]  # 逐个调用某方法
['banana', 'loganberry', 'passion fruit']

可以使用 if 语句过滤一些元素:

>>> [3*x for x in vec if x > 3]  # 仅生成大于三的元素
[12, 18]
>>> [3*x for x in vec if x < 2]  # 仅生成小于二的元素
[]

以下是一些关于循环和其它技巧的演示:

>>> vec1 = [2, 4, 6]
>>> vec2 = [4, 3, -9]
>>> [x*y for x in vec1 for y in vec2]   # 这是一个二重循环,y循环嵌套在x循环嵌中
[8, 6, -18, 16, 12, -36, 24, 18, -54]   # 这也是一个二重循环,与上面那个的区别在于这个使用的是加法运算符
>>> [x+y for x in vec1 for y in vec2]
[6, 5, -7, 8, 7, -5, 10, 9, -3]
>>> [vec1[i]*vec2[i] for i in range(len(vec1))] #以vec1的长度作为循环次数,让两个列表的同一个下标里的元素相乘
[8, 12, -54]

列表推导式可以使用复杂表达式或嵌套函数:

# 在这里round的范围定义的是小数点后面的小数保留多少位
>>> [str(round(355/113, i)) for i in range(1, 6)]  # 通过str函数转换round函数生成的浮点数为字符串类型
['3.1', '3.14', '3.142', '3.1416', '3.14159']

嵌套列表解析

Python的列表还可以嵌套,也就是二维列表。
以下实例展示了3X4的矩阵列表:

matrix = [
    [1, 2, 3, 4],
    [5, 6, 7, 8],
    [9, 10, 11, 12]
]

以下实例将3X4的矩阵列表转换为4X3列表:

print([[row[i] for row in matrix] for i in range(4)])

运行结果:

[[1, 5, 9], [2, 6, 10], [3, 7, 11], [4, 8, 12]]

以上这种转换是通过列表推导式生成的一个新列表,除此之外也可以用循环来实现:

matrix = [
    [1, 2, 3, 4],
    [5, 6, 7, 8],
    [9, 10, 11, 12]
]

j=1
for i in range(4):
    for row in matrix:
        print("[",row[i],"]",end=" ")
        if j%3==0:
            print()
        j += 1

运行结果:

[ 1 ] [ 5 ] [ 9 ] 
[ 2 ] [ 6 ] [ 10 ] 
[ 3 ] [ 7 ] [ 11 ] 
[ 4 ] [ 8 ] [ 12 ]

以下实例也可以实现:

matrix = [
    [1, 2, 3, 4],
    [5, 6, 7, 8],
    [9, 10, 11, 12]
]

transposed = []

for i in range(4):
    transposed.append([row[i] for row in matrix]) #这是通过列表推导式生成出新元素后,添加到一个空的列表中

print(transposed)

运行结果:

[[1, 5, 9], [2, 6, 10], [3, 7, 11], [4, 8, 12]]

还有一种实现方法,这种方式就比较繁琐了:

matrix = [
    [1, 2, 3, 4],
    [5, 6, 7, 8],
    [9, 10, 11, 12]
]

transposed = []

for i in range(4):

    transposed_row = []
    for row in matrix:
        transposed_row.append(row[i]) # 把遍历的元素添加到一个空列表中
    transposed.append(transposed_row) # 然后把这个列表对象添加进来

print(transposed)

运行结果:

[[1, 5, 9], [2, 6, 10], [3, 7, 11], [4, 8, 12]]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值