- 在线时间
- 1630 小时
- 最后登录
- 2024-1-29
- 注册时间
- 2017-5-16
- 听众数
- 82
- 收听数
- 1
- 能力
- 120 分
- 体力
- 559778 点
- 威望
- 12 点
- 阅读权限
- 255
- 积分
- 173306
- 相册
- 1
- 日志
- 0
- 记录
- 0
- 帖子
- 5313
- 主题
- 5273
- 精华
- 18
- 分享
- 0
- 好友
- 163
TA的每日心情 | 开心 2021-8-11 17:59 |
---|
签到天数: 17 天 [LV.4]偶尔看看III 网络挑战赛参赛者 网络挑战赛参赛者 - 自我介绍
- 本人女,毕业于内蒙古科技大学,担任文职专业,毕业专业英语。
 群组: 2018美赛大象算法课程 群组: 2018美赛护航培训课程 群组: 2019年 数学中国站长建 群组: 2019年数据分析师课程 群组: 2018年大象老师国赛优 |
Python实现快速排序和插入排序算法及自定义排序的示例
: Z [+ i, g7 j/ N. B% K; R8 I$ H这篇文章主要介绍了Python实现快速排序和插入排序算法及自定义排序的示例,自定义排序用到了Python的sort和sorted函数,需要的朋友可以参考下1 t# Y: d! R t7 _ h! t
一、快速排序
% W+ S3 q6 `8 g, c+ e/ L( w+ }
3 \$ \0 n% T( l* m+ _' d* {, V( B快速排序(Quicksort)是对冒泡排序的一种改进。由C. A. R. Hoare在1962年提出。它的基本思想是:通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列。/ r: G/ ~0 }# ?1 J! Z
% l* _( Q6 w( t! ^' N7 E! E
快速排序,递归实现
9 I: X' @3 @0 _9 m. e7 V+ Z. ?5 t/ l8 U# I/ l
def quick_sort(num_list):
% b5 D( l4 `5 a) f: e """9 R- d. n$ V8 y! D% K
快速排序
; H2 {' A+ Y8 j4 w1 L """
% Y4 u( X3 @$ U/ }& S5 i if num_list == []:0 ~+ C6 f9 g0 G# V( P
return num_list; @! C9 g) K! l) p- v6 H7 L$ n
smallList = []
W1 h" k# @# o R bigList = []
. p& F/ j2 P1 D( D% W/ C8 ~ middleElement = num_list[0]
3 i6 ~% L& h! k' V$ w5 E for i in num_list[1:]:
% A n/ |2 k/ J' ?$ ]% ~9 }5 z8 l; S if i <= middleElement:" P4 D; I" J7 r# `1 J: N/ D
smallList.append(i)! k+ \ T! M, U4 ^3 `+ h' _
else:
4 t( C I' q: i6 M bigList.append(i)1 Z4 F2 E( S4 S0 k) Y
return quick_sort(smallList)+[middleElement]+quick_sort(bigList)# O4 L' p: O; U- i! _8 c1 v) i
3 N6 g9 h' @# b6 J3 S. G" w7 p: }$ D8 r$ l% o# S
插入排序(Insertion Sort)的算法描述是一种简单直观的排序算法。它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。插入排序在实现上,通常采用in-place排序(即只需用到O(1)的额外空间的排序),因而在从后向前扫描过程中,需要反复把已排序元素逐步向后挪位,为最新元素提供插入空间。 @( E- w, U6 U
! m y: ~3 \& y5 p
插入排序
9 I w* [7 e5 ~0 Y9 l# ]
* G6 T5 r0 e4 {1 ?& ^8 _
, I+ W( U2 u0 `1 Idef insert_sort(num_list):. Q1 X- |# H# n5 _
"""
p+ M2 y9 U" k* b- n6 d) F 插入排序
$ g' M% M# d7 f" B7 S """, ~* e( c$ A5 [
for i in range(len(num_list)-1):
" c8 e7 ~- n' {3 U2 Q6 N& Y for j in range(i+1, len(num_list)):
( x2 d+ B, |, P& f7 V if num_list>num_list[j]: `/ i; N, i2 ]1 @2 }3 I: z/ S
num_list,num_list[j] = num_list[j],num_list
% e! l0 }8 W: n( E+ A6 C) W return num_list
0 i9 H, y9 D; g' E1 ]" E. ]) G: K; M# \
1 o5 k# v% Z7 ]/ }" V
三、自定义排序
6 k8 _/ O- P, @) t- E7 }1 G, a利用 sort() 或 sorted() 的 key 即可实现。% V1 n! Z* k/ @! r ~1 {) N9 A* Q
def sort_key(obj):
# I7 x* p: p) _ sorted_list = [4, 2, 5, 9, 7, 8, 1, 3, 6, 0]# C5 X- X/ P4 E0 I" \
return sorted_list.index(obj)9 g2 F, T2 A: C c/ ?$ _
9 Z! J; {- T+ a2 _5 h1 K2 k
6 q3 O6 V# G6 ^' @ b5 O2 W; g9 j
if __name__ == '__main__':* A# ^) I, P& v
print sorted(range(10), key=sort_key)
* O; y5 o6 R: \6 U1 C3 }$ _
6 m# L }/ P' B# 输出结果如下
3 D1 c3 t& z8 f# q[4, 2, 5, 9, 7, 8, 1, 3, 6, 0]$ r% c7 ?( Y$ ~1 e1 r; V
% e$ S$ c! I* s9 Q' X8 T. U
: h$ [9 b3 G* z8 T) s$ X
非常感谢你的阅读& H9 O/ I H* t- i( s
大学的时候选择了自学python,工作了发现吃了计算机基础不好的亏,学历不行这是
% f9 {0 N3 T7 e8 [没办法的事,只能后天弥补,于是在编码之外开启了自己的逆袭之路,不断的学习python核心知识,深入的研习计算机基础知识,整理好了,如果你也不甘平庸,那就与我一起在编码之外,不断成长吧!% e7 I$ m8 c2 a$ y; ]% d' \
其实这里不仅有技术,更有那些技术之外的东西,比如,如何做一个精致的程序员,而不是“屌丝”,程序员本身就是高贵的一种存在啊,难道不是吗?[点击加入]想做你自己想成为高尚人,加油!: a0 p9 m" q5 e \* S6 n8 i
————————————————
" q8 e4 O- l0 U3 F5 ]' j版权声明:本文为CSDN博主「程序员牡蛎」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。. j3 R/ W: f5 z8 x* J3 Z5 n
原文链接:https://blog.csdn.net/chengxun03/article/details/105460563
& E( c7 }4 p/ ^ K- S& M8 |! \, [; d' w% d- o# f$ P$ t
$ S7 r* n$ ~% e7 A0 b
2 M. H, j7 ]7 f6 N8 x. k. V' o0 O5 v |
zan
|