首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在Bubble_sort程序中获得最少的通过次数( programming)

如何在Bubble_sort程序中获得最少的通过次数( programming)
EN

Stack Overflow用户
提问于 2018-10-25 06:14:13
回答 1查看 344关注 0票数 1

我已经附上了我的气泡分类程序。它给出了正确的答案,但给出了最大的传球次数。如果我以[1,2,3,4,5,6,7]的形式给出输入,那么它也会给出一些passes=6,我试图获得一个最小数量的通行证来运行程序。这意味着对于给定的示例1或2传递,因为它们已经处于升序。

我怎么才能拿到最低限度的通行证??

代码语言:javascript
复制
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)
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-10-25 06:22:11

外部循环应该向后计数,这样内循环移动到后面的较大值就可以留在后面,并且应该在0之前停止,因为剩下的最后一项必须最小。

更改:

代码语言:javascript
复制
for num in range(0,len(list)-1):

至:

代码语言:javascript
复制
for num in range(len(list)-1, 0, -1):
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/52982475

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档