日 - 列表功能(功能.列表...)

wufei1232025-01-08python11

日 - 列表功能

Python 列表提供了丰富的操作方法,本文将重点介绍 extend()、append()、insert()、reverse()、sort() 和 sorted() 等方法,并结合示例讲解其用法。此外,还将演示如何查找列表中的最小值、最大值、第二小值和第二大值,以及 in 和 not in 运算符的使用,最后以字符串反转和冒泡排序算法为例,进一步巩固列表操作技巧。

列表扩展与追加:

  • extend(): 将可迭代对象(如列表、元组)的所有元素添加到列表末尾。
l1 = [10, 20, 30]
l2 = [40, 50, 60]
l1.extend(l2)
print(l1)  # 输出: [10, 20, 30, 40, 50, 60]
print(len(l1))  # 输出: 6
  • append(): 将单个元素添加到列表末尾。注意,append() 添加的是整个元素,而不是元素的各个组成部分。
l1 = [10, 20, 30]
l2 = [40, 50, 60]
l1.append(l2)
print(l1)  # 输出: [10, 20, 30, [40, 50, 60]]
print(len(l1))  # 输出: 4
  • insert(): 在列表指定索引处插入单个元素。
l1 = [10, 20, 30]
l1.insert(1, 15)  # 在索引 1 处插入 15
print(l1)  # 输出: [10, 15, 20, 30]

append() 和 extend() 的区别:append() 添加的是一个元素,而 extend() 添加的是多个元素。

l1 = [10, 20, 30]
l1.append('abcd')
print(l1)  # 输出: [10, 20, 30, 'abcd']
l1.extend('pqrs')
print(l1)  # 输出: [10, 20, 30, 'abcd', 'p', 'q', 'r', 's']

列表反转与排序:

  • reverse(): 就地反转列表元素顺序。
l1 = [10, 20, 30]
l1.reverse()
print(l1)  # 输出: [30, 20, 10]
  • sort(): 就地排序列表元素(默认升序)。
l1 = [10, 200, 30]
l1.sort()
print(l1)  # 输出: [10, 30, 200]
l1.sort(reverse=True)
print(l1)  # 输出: [200, 30, 10]
  • sorted(): 返回一个新的已排序列表,不修改原始列表。
my_list = [3, 1, 4, 5, 2]
sorted_list = sorted(my_list)
print(sorted_list)  # 输出: [1, 2, 3, 4, 5]
print(my_list)  # 输出: [3, 1, 4, 5, 2]

列表统计函数:

  • min(): 查找最小值。
  • max(): 查找最大值。
  • sum(): 查找所有元素的和。
l1 = [10, 200, 30, 40, 50]
print(min(l1))  # 输出: 10
print(max(l1))  # 输出: 200
print(sum(l1))  # 输出: 330

使用 float('inf') 和 -float('inf') 分别表示正无穷和负无穷,可以方便地查找第二小值和第二大值:

l1 = [10, 20, 310, 40, 50]
min_value = float('inf')
second_min = float('inf')
for x in l1:
    if x < min_value:
        second_min = min_value
        min_value = x
    elif x < second_min and x != min_value:
        second_min = x
print(second_min)  # 输出: 20


l1 = [10, 20, 30, 40, 50]
max_value = -float('inf')
second_max = -float('inf')
for x in l1:
    if x > max_value:
        second_max = max_value
        max_value = x
    elif x > second_max and x != max_value:
        second_max = x
print(second_max)  # 输出: 40

成员运算符:

  • in: 检查元素是否在列表中。
  • not in: 检查元素是否不在列表中。
l1 = [100, 67, 54, 101, 220, 670, 45, 32]
print(100 in l1)  # 输出: True
print(100 not in l1)  # 输出: False
print(120 in l1)  # 输出: False
print(120 not in l1)  # 输出: True

字符串反转和冒泡排序:

字符串反转:

s = "today is thursday"
reverse = s[::-1] #利用切片反转
print(reverse)  # 输出: yadruht si yadot

冒泡排序 (示例:升序排列):

l1 = [40, 30, 20, 10]
n = len(l1)
for i in range(n):
    for j in range(0, n-i-1):
        if l1[j] > l1[j+1]:
            l1[j], l1[j+1] = l1[j+1], l1[j]
print(l1)  # 输出: [10, 20, 30, 40]

通过以上示例,您可以更深入地理解 Python 列表的各种操作方法,并能够灵活运用它们来解决实际问题。 记住,选择合适的方法可以显著提高代码效率和可读性。

以上就是日 - 列表功能的详细内容,更多请关注知识资源分享宝库其它相关文章!

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。