在python中排序数字

时间:2013-10-29 15:56:28

标签: python sorting

我正在尝试获取一个函数,如果你进行排序(listname),它会将该列表中的所有数字从最小到最大排序。

我不确定我的错是什么,但是我需要一些帮助,因为输出实际上并不是最小的,对于前两个数字而言,它最小到最大。

示例:

  

如果列表中有23,212,44而不是我的排序,那么输出将是这样的。

输出

  

212,23,44

应该 23,44,212。

代码:

def sort(my_list):
    size = len(my_list)
    for i in range(size):
        for j in range(size-i-1):
            if(my_list[j] > my_list[j+1]):
                tmp = my_list[j]
                my_list[j] = my_list[j+1]
                my_list[j+1] = tmp

更多代码:

numbers=([])
amount=input("How many numbers are in your list? ")
print("")
counter = 0
ran = 0
while counter < int(amount):
    counter = counter + 1
    ran = ran + 1
    num3 = input(str(ran) + ". Input: ")
    try:
       val = int(num3)
    except ValueError:
       num3 = input(str(ran) + ". Input: ")
    sort(numbers)
    numbers.append(num3)

3 个答案:

答案 0 :(得分:4)

看起来你的列表中不包含任何数字而是字符串。 Python不会试图猜测这些字符串中可能包含的内容,因此您会得到奇怪的排序顺序。

您有两种选择:

  1. 在比较列表元素(int
  2. 之前,将列表元素转换为if(int(my_list[j]) > int(my_list[j+1])):
  3. 在此网站上搜索python natural sort以获取如何在Python中实现“自然排序”的答案。

答案 1 :(得分:3)

如果您只想对其进行排序,请使用sorted:

sorted_my_list = sorted(my_list,key=int)

或者对其进行排序,使用

my_list.sort(key=int)

如果您想修复程序,请将my_list转换为整数或至少比较整数

if ( int(my_list[j]) > int(my_list[j+1])):

此外,您可以在一个语句中交换两个变量:

my_list[j],my_list[j+1] = my_list[j+1],my_list[j]

答案 2 :(得分:0)

我刚刚使用了您的代码(刚刚添加了return语句)。它返回预期值:

def sort(my_list):
    size = len(my_list)
    for i in range(size):
        for j in range(size-i-1):
            if(my_list[j] > my_list[j+1]):
                tmp = my_list[j]
                my_list[j] = my_list[j+1]
                my_list[j+1] = tmp
    return my_list # Note I added this return statement

print sort([23,212,44])
>>> 
[23, 44, 212]