zoukankan      html  css  js  c++  java
  • python 列表排序方法reverse、sort、sorted基础篇

    python语言中的列表排序方法有三个:reverse反转/倒序排序、sort正序排序、sorted可以获取排序后的列表。在更高级列表排序中,后两中方法还可以加入条件参数进行排序。

    reverse()方法

    将列表中元素反转排序,比如下面这样

    >>> x = [1,5,2,3,4] 
    >>> x.reverse() 
    >>> x 
    [43251]

    reverse列表反转排序:是把原列表中的元素顺序从左至右的重新存放,而不会对列表中的参数进行排序整理。如果需要对列表中的参数进行整理,就需要用到列表的另一种排序方式sort正序排序。

    sort()排序方法

    此函数方法对列表内容进行正向排序,排序后的新列表会覆盖原列表(id不变),也就是sort排序方法是直接修改原列表list排序方法。

    >>> a = [5,7,6,3,4,1,2] 
    >>> a.sort() 
    >>> a 
    [1234567]

    许多python初学者,对sort()方法比较糊涂。有的时候会需要一个排序好的列表,而又想保存原有未排序列表,他们会这么操作:

    >>> a = [5,7,6,3,4,1,2] 
    >>> b = a.sort() 
    >>> print b 
    None

    这个时候问题出现了,变量b得到的是一个空值。那么想要得到排序好的列表,又想保留原列表怎么办呢?列表sorted()方法可以帮你实现。

    sorted()方法

    即可以保留原列表,又能得到已经排序好的列表sorted()操作方法如下:

    >>> a = [5,7,6,3,4,1,2] 
    >>> b = sorted(a) 
    >>> a 
    [5763412] 
    >>> b 
    [1234567]

    sorted()方法可以用在任何数据类型的序列中,返回的总是一个列表形式:

    >>> sorted('iplaypython.com') 
    ['.''a''c''h''i''l''m''n''o''o''p''p''t''y''y']

    三者的区别

    sort()是可变对象(字典、列表)的方法,无参数,无返回值,sort()会改变可变对象,因此无需返回值。sort()方法是可变对象独有的方法或者属性,而作为不可变对象如元组、字符串是不具有这些方法的,如果调用将会返回一个异常。

    >>> a=[5,4,3,2,1] 
    >>> a.sort() 
    >>>  
    >>> a 
    [12345]

    sorted()是python的内置函数,并不是可变对象(列表、字典)的特有方法,sorted()函数需要一个参数(参数可以是列表、字典、元组、字符串),无论传递什么参数,都将返回一个以列表为容器的返回值,如果是字典将返回键的列表。

    >>> mystring="54321"
    >>> mytuple=(5,4,3,2,1) 
    >>> mylist=[5,4,3,2,1] 
    >>> sorted(mystring) 
    ['1''2''3''4''5'] 
    >>> sorted(mytuple) 
    [12345] 
    >>> sorted(mylist) 
    [12345]

    reverse()与sort的使用方式一样,而reversed()与sorted()的使用方式相同

    >>> mylist=[5,4,3,2,1] 
    >>> mylist.reverse() 
    >>> mylist 
    [12345] 
    >>> mylist=[5,4,3,2,1] 
    >>> for i in reversed(mylist): 
    ...   print i, 
    ...  
    1 2 3 4 5

    通过序列的切片也可以达到“逆转”的效果

    >>> mystring="54321"
    >>> mytuple=(5,4,3,2,1) 
    >>> mylist=[5,4,3,2,1] 
    >>> mystring[::-1] 
    '12345'
    >>> mytuple[::-1] 
    (12345) 
    >>> mylist[::-1] 
    [12345]
  • 相关阅读:
    floyd的魔改应用——洛谷P2419 [USACO08JAN]牛大赛Cow Contest 题解
    洛谷P2142 高精度减法 题解
    浅谈SPFA——洛谷P1576 最小花费 题解
    洛谷P1301 魔鬼之城 题解
    洛谷P1009 阶乘之和 题解
    20200926模拟
    [NOIP 2013]货车运输
    带权并查集--P2024 [NOI2001]食物链
    归并排序/树状数组求逆序对-lgP1908 逆序对
    LCA模块+求树上两点距离最短
  • 原文地址:https://www.cnblogs.com/whaben/p/6495566.html
Copyright © 2011-2022 走看看