首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >ShellSort降序

ShellSort降序
EN

Stack Overflow用户
提问于 2019-09-15 06:41:28
回答 1查看 1.5K关注 0票数 1

因此,我的程序目前按升序排列shellSorts,但我需要按降序排序。我想要一些帮助,我应该改变什么,使它按降序排序。注意,内置的排序函数是不允许的,例如排序(数组,reverse=True)

代码语言:javascript
复制
def shellSort(array):
    n = len(array) 
    gap = n // 2
    while gap > 0: 
        for i in range(gap, n): 
            temp = array[i] 
            j = i 
            while  j >= gap and array[j - gap] < temp: 
                array[j] = array[j - gap]
                j -= gap  
            array[j] = temp 
        gap //= 2

array = []

while True:
    try:
        user_input = input().split()
        array.append(user_input)
    except EOFError:
        break

for i in array:
    shellSort(i)
    print(' '.join(i))
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-09-15 06:58:56

更改:

代码语言:javascript
复制
while  j >= gap and array[j - gap] > temp:

至:

代码语言:javascript
复制
while  j >= gap and array[j - gap] < temp:

因此:

代码语言:javascript
复制
array = [2, 5, 4, 8, 1]
shellSort(array)
print(array)

将产出:

代码语言:javascript
复制
[8, 5, 4, 2, 1]
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/57941753

复制
相关文章

相似问题

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