Python 数组(列表)排序详解

        在Python中,数组的概念并不直接对应其他编程语言中的数组,因为Python中的列表(List)提供了更加灵活和强大的功能,通常被视为数组的一种高级实现。列表是Python中最常用的数据结构之一,它支持动态地添加、删除和修改元素,同时也支持排序操作。本文将详细介绍如何在Python中对列表进行排序,包括使用内置函数、自定义排序规则等。

1. 使用sorted()函数

sorted()是Python的一个内置函数,它可以对任何可迭代对象进行排序,并返回一个新的列表,原列表不会被修改。

基本用法
numbers = [3, 1, 4, 1, 5, 9, 2] 
sorted_numbers = sorted(numbers) 
print(sorted_numbers) # 输出: [1, 1, 2, 3, 4, 5, 9]

指定排序关键字(key参数)

如果列表中的元素是复杂的数据结构(如字典、元组等),可以使用key参数指定一个函数,该函数会在每个元素上调用,其返回值作为排序的依据。

students = [ 
{'name': 'Alice', 'age': 22}, 
{'name': 'Bob', 'age': 19}, 
{'name': 'Charlie', 'age': 20} 
] 
sorted_students = sorted(students, key=lambda x: x['age']) 
print(sorted_students) 
# 输出按年龄排序的学生列表
逆序排序(reverse参数)

sorted()函数还有一个reverse参数,当设置为True时,可以进行逆序(降序)排序。

numbers = [3, 1, 4, 1, 5, 9, 2] 
sorted_numbers_desc = sorted(numbers, reverse=True) 
print(sorted_numbers_desc) # 输出: [9, 5, 4, 3, 2, 1, 1]

2. 使用列表的sort()方法

sorted()函数不同,列表的sort()方法会直接在原列表上进行排序,不返回新的列表。

基本用法
numbers = [3, 1, 4, 1, 5, 9, 2] 
numbers.sort() 
print(numbers) # 输出: [1, 1, 2, 3, 4, 5, 9]

指定排序关键字和逆序排序

sort()方法也支持keyreverse参数,用法与sorted()相同。

students = [ 
{'name': 'Alice', 'age': 22}, 
{'name': 'Bob', 'age': 19}, 
{'name': 'Charlie', 'age': 20} 
] 
students.sort(key=lambda x: x['age']) 
print(students) # 输出按年龄排序的学生列表 


students.sort(key=lambda x: x['age'], reverse=True) 
print(students) # 输出按年龄逆序排序的学生列表

3. 自定义排序逻辑

        无论是sorted()函数还是sort()方法,都允许通过key参数指定一个函数来自定义排序逻辑。这个函数会在排序过程中被应用到列表的每个元素上,其返回值作为排序的依据。

       

# 冒泡排序
def bubble_sort(arr):
    n = len(arr)
    for i in range(n):
        for j in range(0, n - i - 1):
            if arr[j] > arr[j + 1]:
                arr[j], arr[j + 1] = arr[j + 1], arr[j]
    return arr


# 示例使用
array = [64, 34, 25, 12, 22, 11, 90]
sorted_array = bubble_sort(array)
print("Sorted array is:", sorted_array)
# 快速排序
def quicksort(arr):
    if len(arr) <= 1:
        return arr
    pivot = arr[len(arr) // 2]
    left = [x for x in arr if x < pivot]
    middle = [x for x in arr if x == pivot]
    right = [x for x in arr if x > pivot]
    return quicksort(left) + middle + quicksort(right)
 
# 示例使用
arr = [3, 6, 8, 10, 1, 2, 1, 4, 7, 9]
sorted_arr = quicksort(arr)
print(sorted_arr)  # 输出: [1, 1, 2, 3, 4, 6, 7, 8, 9, 10]
# 通过set 去重
# 原始列表
original_list = [3, 2, 1, 5, 2, 3, 4, 5, 7, 7, 8]
 
# 去重并排序
sorted_list = sorted(list(set(original_list)))
 
print(sorted_list)

4. 注意事项

  • sorted()函数返回一个新的列表,原列表不变。
  • sort()方法直接在原列表上进行排序,不返回新列表。
  • 当需要按照多个条件进行排序时,可以在key参数中返回一个元组,元组中的元素将依次作为排序的依据。

结论

        Python提供了灵活的排序机制,通过sorted()函数和列表的sort()方法,可以方便地对列表进行排序。无论是简单的数字列表,还是包含复杂数据结构的列表,都可以通过指定排序关键字、逆序排序等方式来满足不同的排序需求。掌握这些排序技巧,将有助于提高Python编程的效率和灵活性。

  • 6
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python中,可以使用两种方法对一维数组进行排序,即使用sorted函数和sort方法。这两种方法有一些区别。使用sorted函数时,它不会修改原来的数组,而是返回一个新的已排序数组。例如,如果有一个数组num_list,可以使用sorted(num_list)来对其进行排序排序结果将被存储在一个新的数组中。而使用sort方法时,它会直接在原数组上进行排序,不返回新的数组。例如,如果有一个数组num_list,可以使用num_list.sort()来对其进行排序排序结果将直接反映在原数组上。因此,建议使用sorted函数进行排序,因为它不会修改原数组,更加灵活。而sort方法虽然代码更简洁,但会修改原数组,这可能会在调试时带来麻烦,特别是当多个地方同时使用了这个数组时。 #### 引用[.reference_title] - *1* *3* [python数组排序方法详解(sort, sorted,argsort)](https://blog.csdn.net/weixin_43721000/article/details/120504199)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [1119: 一维数组排序 Python](https://blog.csdn.net/m0_45306379/article/details/121031012)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值