一个显示排序过程的Python脚本
之前向大家介绍过《一个排序算法比较的网站》,那个网站用动画演示了各种排序算法,并分析了各种排序算法。这里,要向大家推荐一个Python脚本,其可以把排序的过程给显示出来。
下图是“冒泡排序”的一个示例,其中:
折线表示了各个元素的位置变化。
折线的深浅表示了元素的大小。越深则越大。

同样,还有其它一些排序算法的图片:
堆排序(Heap Sort)

选择排序(Selection)

快速排序(Quick)

Shell排序

插入排序(Insertion)

你可以使用如下的Python代码来制作这些图片:(需要 Cairo图片库支持)
Python排序脚本
这个脚本参数如下:
-a 表示使用什么样的算法,取值为"quick", "heap", "selection", "insertion", "bubble", "shell"。
-n 表示要排序的数据个数。
-f 表示输入文件。
-p 表示文件前缀。
-d 表示输出顺序。
-x 图片宽度。
-y 图片高度。
-l 所有线的宽度。
-b 边界宽度。
使用示例如下:
./visualise.py -l 6 -x 700 -y 300 -n 15
文章:来源
转载于酷壳CoolShell 无删改 仅以此纪念陈皓(左耳朵耗子)
相信大家看过《简明Vim教程》也玩了《Vim大冒险》的游戏了,相信大家对Vim都有一个好的入门了。我在这里把我日常用Vim编程的一些技巧列出来给大家看看,希望对大家有用,另外,…
以前用的 nextcloud ,用手机 app 查看照片,照片打开比较慢。 有什么其他好的照片服务器软件可用? 功能不需要太复杂,主要争对照片管理,在 linux 上安装尽量简…
后悔使用双拼 先叠个甲,练习时长一年多,可能是我使用的方式有问题吧。 理由如下: 会非常吃手感,我状态好的时候打字确实比全拼快,但是状态差的时候,打字会比全拼慢很多很多(这一…
合速度