实现希尔排序——Python(希尔排序实现代码)

关于希尔排序

希尔排序(Shell's Sort)是插入排序的一种又称“缩小增量排序”(Diminishing Increment Sort),是直接插入排序算法的一种更高效的改进版本。希尔排序是非稳定排序算法。该方法因 D.L.Shell 于 1959 年提出而得名。

希尔排序是把记录按下标的一定增量分组,对每组使用直接插入排序算法排序;随着增量逐渐减少,每组包含的关键词越来越多,当增量减至 1 时,整个文件恰被分成一组,算法便终止。

算法步骤:选择一个增量序列 t1,t2,……,tk,其中 ti > tj, tk = 1;按增量序列个数 k,对序列进行 k 趟排序;每趟排序,根据对应的增量 ti,将待排序列分割成若干长度为 m 的子序列,分别对各子表进行直接插入排序。仅增量因子为 1 时,整个序列作为一个表来处理,表长度即为整个序列的长度。

代码

# 手动输入数列
def main():
    text = input("请输入整数数列,以空格隔开>>\n")
    type = int(input("升序排列请输入1,降序排列请输入2>>\n"))
    nums = text.split() #将字符串转为数组
    orderNums = shellSort(nums,type)
    print("排序后的数列:",orderNums)

def shellSort(nums,type):
    import math
    gap = 1
    while (gap < len(nums) / 3):
        gap = gap * 3 + 1
    while gap > 0:
        for i in range(gap, len(nums)):
            temp = nums[i]
            j = i - gap
            while j >= 0 and int(nums[j]) > int(temp):
                nums[j + gap] = nums[j]
                j -= gap
            nums[j + gap] = temp
        gap = math.floor(gap / 3)
    return nums

#运行主程序
main()


总结

知识点总结:

1. 首次用到了import,调用其他模块时,需要首先引入该模块;

相关文章

Python 3.14 的 UUIDv6/v7/v8 上新,别再用 uuid4 () 啦!

Python 3.14 重磅更新!UUIDv6/v7/v8 强势来袭,别再用 uuid4 () 啦! 为什么说 UUID 升级是 2025 年 Python 开发者的必学技能?在当今互联网应用中,UU...

Python 中实现选择排序(python中的选择排序算法)

选择排序算法在每次迭代中从未排序的列表中找到最小的元素,并将该元素放在未排序列表的开头。也可以查找最大值,实现降序排序。选择排序的执行过程对于列表使用选择排序算法进行升序排序:循环迭代列表,将第一个元...

Python学不会来打我(94)python序列的知识点总结

在Python中,序列(Sequence)是一种基础数据结构,具有以下核心特征和类型划分:#python##python自学##python教程#1. 序列的定义与特性定义:序列是一块可存放多个...

你应该知道的关于 Python 排序的 4 个技巧

介绍在本文中,你将了解一些你以前可能不知道的关于排序的技巧。目录Sorted() VS Sort() 用于列表、元组和字典根据你的标准排序对复杂对象的集合进行排序用内置函数attrgetter进行排序...

Python教程-列表排序(python中如何给列表排序)

作为软件开发者,我们总是努力编写干净、简洁、高效的代码。Python 是一种强大的编程语言,它有许多内置的函数和库。其中一个库是 "列表 "模块,它提供了强大的工具来管理 Python...