python - 如何在 Bubble_sort 程序中获得最少的通过次数(Python 编程)
问题描述
我附上了我的冒泡排序程序。它给出了正确的答案,但给出了最大的通过次数。如果我给出输入,[1,2,3,4,5,6,7]
那么它也会给出一些pass = 6。我正在尝试获得最少的通过次数以使程序运行。这意味着对于给定的示例 1 或 2 次通过,因为它们已经按升序排列。
我将如何获得最少的通行证?
def bubbleSort(list):
global count
count=0;
for num in range(0,len(list)-1):
count=count+1
for i in range(0,len(list)-1-num):
if list[i]>list[i+1]:
list[i], list[i+1] = list[i+1], list[i]
print("pass",count, ":",list)
return(list,count)
list=[]
list1=[]
str=str(input("Enter the elements of the list seperated by comma:"))
list1=str.split(",")
for i in list1:
list.append(int(i))
print("Original List:",list)
bubbleSort(list);
print("Sorted list:",list)
print("Number of Passes:",count)
解决方案
您的外循环应该倒数,以便内循环移到后面的较大值可以留在后面,并且它应该在 0 之前停止,因为剩下的最后一项必须是最小的。
改变:
for num in range(0,len(list)-1):
至:
for num in range(len(list)-1, 0, -1):
推荐阅读
- c# - C# 使用基表单类隐藏表单控件
- android - 将带条件的循环转换为 RxJava 流
- mysql - 如何减少视图的执行时间?
- graphql - 如何在 GraphQL 中将多个对象作为数组返回
- android - 是否有可能做到这一点?从选择图像到捕获图像
- javascript - Uncaught SecurityError: Blocked a frame with origin \"null\" from access a cross-origin frame
- python - 如何在我的目录中的所有文件夹上运行子进程?
- python - 在 Python 中使用赋值表达式时如何完成赋值语句“x = y := f(x)”?
- machine-learning - PCANET中的线性层(卷积层)
- pandas - 在多列 DataFrame 上获取日志值