- 在线时间
- 514 小时
- 最后登录
- 2023-12-1
- 注册时间
- 2018-7-17
- 听众数
- 15
- 收听数
- 0
- 能力
- 0 分
- 体力
- 40214 点
- 威望
- 0 点
- 阅读权限
- 255
- 积分
- 12775
- 相册
- 0
- 日志
- 0
- 记录
- 0
- 帖子
- 1419
- 主题
- 1178
- 精华
- 0
- 分享
- 0
- 好友
- 15
TA的每日心情 | 开心 2023-7-31 10:17 |
|---|
签到天数: 198 天 [LV.7]常住居民III
- 自我介绍
- 数学中国浅夏
 |
Python 希尔排序
$ ^6 a$ R# z* H( Y' N/ ?$ ^& q希尔排序,也称递减增量排序算法,是插入排序的一种更高效的改进版本。但希尔排序是非稳定排序算法。
! T3 H% b" O* W+ P8 b; J希尔排序的基本思想是:先将整个待排序的记录序列分割成为若干子序列分别进行直接插入排序,待整个序列中的记录"基本有序"时,再对全体记录进行依次直接插入排序。
6 _3 a% ^( d- e! ~ ![]()
1 y3 r* p& B; x& \1 C/ H& o" f
! x- o9 M; s3 I7 t3 B/ j' L/ B4 ^2 v def shellSort(arr):
5 b2 o5 r1 x# o& M
4 f0 m0 B1 H- Q# X0 z$ a n = len(arr)
! n& ~. X" f) h, ?. s, P gap = int(n/2)7 g; ?) U$ L* m& U
3 {$ l1 i+ x3 x" l0 `0 R- M* i while gap > 0: e" Z6 n: z f5 z
" f: F m% s4 Q& d6 r8 @4 n2 }; ^
for i in range(gap,n): 9 v; j8 Q, s9 A' v$ E8 j: [3 p* _
4 `5 R1 S: [) \
temp = arr / p6 T8 R2 \- O F' O$ I" L
j = i ' `4 y$ |$ }1 q9 q! F# T N/ j7 }3 r
while j >= gap and arr[j-gap] >temp:
6 O6 h4 [) V3 y3 g* ?+ }" m arr[j] = arr[j-gap]
6 E' r* v0 f1 M3 w j -= gap
# A' d+ r: m. x" b3 C. s( a) ` arr[j] = temp
3 s& E6 T& X% q1 o6 F8 z" A; f; | gap = int(gap/2)
% ~6 j# u' X2 X) v1 }& G. f5 U+ r6 c2 E3 |7 `
arr = [ 12, 34, 54, 2, 3]
2 F# |: } v5 N1 R/ i' e) j- Q! h" v c9 D- L1 W! {
n = len(arr)
. h- x( Q% ]: ?2 Lprint ("排序前:")
9 I" w/ o6 K' k l, z% z2 Dfor i in range(n):
' A0 p6 R4 Y! F8 G print(arr), 5 ~# E2 i$ _% H/ @3 I" N4 l
. B8 p+ \2 }9 x7 Z( P" T- ]' b; s: d
shellSort(arr) : q9 M1 X: q/ o6 Y# D
8 ^- g5 q! V1 {0 H6 q+ l1 }
print ("\n排序后:") 7 D* c% Q) {3 k! {+ I0 O- V- `
for i in range(n): 5 k" L9 t6 n9 b( g, l2 Q
print(arr),
7 D) b! y8 T6 @! h) T6 k+ s7 M9 w- I2 K
执行以上代码输出结果为:) ^2 i5 z; @5 G9 w1 p# O
排序前:12% A* I, j: ^3 j, D* Q
34- o+ E% J' {" o/ w, H$ U: r; v
545 J7 ] x g4 E g* f! k2 `/ E
26 w" z( C" T2 @* _5 G; c
39 D! R1 _2 b' w/ n6 }) x
9 s+ @+ C2 Q0 Z k- q6 @1 l5 [
排序后:" ?6 W$ W. x: Y! H& n5 i
2
- ~7 L6 @" a+ j- L31 x2 G; k0 ~& l, v+ Y
12
6 H. Z! L4 c0 r, R341 J8 Z0 }& q3 k2 H+ A( E( H) w
54/ l4 p' z2 Z& m: L8 N% h% t2 z
4 P% R0 O' k8 r" F
2 M/ y+ {3 p% G# g' y2 U/ R! h W3 O
+ J) D$ h: B7 l% {
3 D! i$ n5 F& F+ L( W9 h p |
zan
|