QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 1564|回复: 0
打印 上一主题 下一主题

Python实现快速排序和插入排序算法及自定义排序的示例

[复制链接]
字体大小: 正常 放大
杨利霞        

5273

主题

82

听众

17万

积分

  • TA的每日心情
    开心
    2021-8-11 17:59
  • 签到天数: 17 天

    [LV.4]偶尔看看III

    网络挑战赛参赛者

    网络挑战赛参赛者

    自我介绍
    本人女,毕业于内蒙古科技大学,担任文职专业,毕业专业英语。

    群组2018美赛大象算法课程

    群组2018美赛护航培训课程

    群组2019年 数学中国站长建

    群组2019年数据分析师课程

    群组2018年大象老师国赛优

    跳转到指定楼层
    1#
    发表于 2020-4-12 11:41 |只看该作者 |正序浏览
    |招呼Ta 关注Ta
    Python实现快速排序和插入排序算法及自定义排序的示例* X/ G8 j# {% l  }. `
    这篇文章主要介绍了Python实现快速排序和插入排序算法及自定义排序的示例,自定义排序用到了Python的sort和sorted函数,需要的朋友可以参考下
    + W4 C8 C! u# U& k一、快速排序# C1 c; C0 D7 x% q, k

    ! \2 B0 ^( k& ]9 `  G: U快速排序(Quicksort)是对冒泡排序的一种改进。由C. A. R. Hoare在1962年提出。它的基本思想是:通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列。
    ; p! J9 c4 b3 \0 S/ y
      C/ J- r% x5 }5 K. e. F快速排序,递归实现9 J) X+ F  Q# f6 s' m" G

    ) H! v6 @! u8 O+ h& }    def quick_sort(num_list):
    3 l+ T' m2 k' l! H+ A9 d7 }  """- Z+ x# p5 E. o+ B9 l* W
      快速排序% R8 \, {! C  h; K" S1 k# ~! q! r
      """
    / y4 [7 s9 b& z. }  if num_list == []:. ?. m  E. }- O& E
        return num_list
    % z$ M# l) u8 M. D. }$ C1 M, L  smallList = []
      G5 s. [7 a5 S  bigList = []
    2 H% M2 I/ S+ `  middleElement = num_list[0]5 G* D$ f, i5 b0 c' [. R5 k/ T6 [
      for i in num_list[1:]:
    3 y5 \' z3 P. H9 e3 f. v% u* o    if i <= middleElement:
    " n" Y  T4 [% `" k9 F" \7 T      smallList.append(i)
    ; ^+ H7 v1 b$ d! d7 f% E5 {$ @    else:
    6 A: Z. }" `0 u1 o. c( ?: L      bigList.append(i)% |2 T, ?8 {( x" S8 @
      return quick_sort(smallList)+[middleElement]+quick_sort(bigList)
    - A5 `' d' D4 g
    , U' e7 E( O5 a1 n, {" c# q7 Q; N3 U' Q9 W0 K3 D5 f7 D3 B
    插入排序(Insertion Sort)的算法描述是一种简单直观的排序算法。它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。插入排序在实现上,通常采用in-place排序(即只需用到O(1)的额外空间的排序),因而在从后向前扫描过程中,需要反复把已排序元素逐步向后挪位,为最新元素提供插入空间。
    ; v% _) \! o1 J) q( f% ~, q' x$ C: |4 V9 N$ V
    插入排序6 T' H& Q8 I7 w  E
    & R2 U! w* D/ s& E
      A' h' j  H. O% z! v3 U0 @) v
    def insert_sort(num_list):+ L/ x/ H6 A! {
      """
    1 I& |4 N% [0 G# M+ v: i8 H  插入排序5 T9 Y$ X8 r( c4 f. @. Y" i- W
      """
    ' c  S7 _# a" `( o! P/ u- e% X  for i in range(len(num_list)-1):
    6 U/ M2 e# {5 ^8 J2 D$ g    for j in range(i+1, len(num_list)):
    2 X9 E" }$ s: W: T3 d      if num_list>num_list[j]:
    4 c' k* ^4 s" i! L$ K% K. \        num_list,num_list[j] = num_list[j],num_list
    0 N7 R4 j# m! ?  return num_list
    8 c5 P) c4 g2 V7 \1 T7 ^, w& G, f$ C$ b/ E- o

    ; T, H% A9 A4 e/ Y三、自定义排序/ ~# s% ^# M" G& |
    利用 sort() 或 sorted() 的 key 即可实现。5 d5 K$ D6 C3 S& K3 N  v; H7 ~
    def sort_key(obj):6 C6 N# I3 u3 _+ i8 x) ]+ H+ ?, A4 x
      sorted_list = [4, 2, 5, 9, 7, 8, 1, 3, 6, 0]" e. A+ _3 o/ A+ }
      return sorted_list.index(obj); r, b) n9 Z4 v, D( _- X
    5 h2 p1 `2 L( T
    0 s$ M: {& e  l4 I* |
    if __name__ == '__main__':3 L8 \8 D: U$ T7 C! n
      print sorted(range(10), key=sort_key)" R& N/ W. l' M* v  U9 n

    9 X6 y* v# \8 D1 @% E# 输出结果如下
    6 {( i4 n% B; Y2 S6 B  x[4, 2, 5, 9, 7, 8, 1, 3, 6, 0]
    6 @5 n+ ^1 y5 Y0 g3 K
    " @" S( u( o9 r! L8 O' N" g
    - ~. q; K. o) l) K0 Q非常感谢你的阅读
    7 C5 \" m& X* s5 J( o0 T2 a7 Y大学的时候选择了自学python,工作了发现吃了计算机基础不好的亏,学历不行这是% a+ |% Y0 I+ h5 R1 J
    没办法的事,只能后天弥补,于是在编码之外开启了自己的逆袭之路,不断的学习python核心知识,深入的研习计算机基础知识,整理好了,如果你也不甘平庸,那就与我一起在编码之外,不断成长吧!; W; q. ?( p! p& a, ~* N
    其实这里不仅有技术,更有那些技术之外的东西,比如,如何做一个精致的程序员,而不是“屌丝”,程序员本身就是高贵的一种存在啊,难道不是吗?[点击加入]想做你自己想成为高尚人,加油!, O% Q( V/ o( {5 F3 m# P2 S
    ————————————————; I( A9 A; t& n; L/ {
    版权声明:本文为CSDN博主「程序员牡蛎」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
    9 N  b9 u' f( y; R( Q: @; R1 @原文链接:https://blog.csdn.net/chengxun03/article/details/105460563' N, A6 ]  Q$ r2 I
    * g$ t, k) N$ g  T* {) u0 t" c
    8 \4 E2 h3 R  A+ R! {( H: u, j
    ) K3 M% K* g4 Q1 I' n( r
    zan
    转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2026-6-10 00:30 , Processed in 0.527238 second(s), 52 queries .

    回顶部