日 – 列表功能

日 - 列表功能

Python 列表提供了丰富的操作方法,本文将重点介绍 extend()append()insert()reverse()sort()sorted() 等方法,并结合示例讲解其用法。此外,还将演示如何查找列表中的最小值、最大值、第二小值和第二大值,以及 innot 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 处插入 15print(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))  # 输出: 10print(max(l1))  # 输出: 200print(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  max_value:        second_max = max_value        max_value = x    elif x > second_max and x != max_value:        second_max = xprint(second_max)  # 输出: 40

成员运算符:

in: 检查元素是否在列表中。not in: 检查元素是否不在列表中。

l1 = [100, 67, 54, 101, 220, 670, 45, 32]print(100 in l1)  # 输出: Trueprint(100 not in l1)  # 输出: Falseprint(120 in l1)  # 输出: Falseprint(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 列表的各种操作方法,并能够灵活运用它们来解决实际问题。 记住,选择合适的方法可以显著提高代码效率和可读性。

以上就是日 – 列表功能的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1355232.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月13日 19:06:44
下一篇 2025年12月13日 19:06:52

相关推荐

发表回复

登录后才能评论
关注微信