我正在尝试获取一个函数,如果你进行排序(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)
答案 0 :(得分:4)
看起来你的列表中不包含任何数字而是字符串。 Python不会试图猜测这些字符串中可能包含的内容,因此您会得到奇怪的排序顺序。
您有两种选择:
int
)if(int(my_list[j]) > int(my_list[j+1])):
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]