日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

插入排序(python)

系統(tǒng) 1888 0

3. 插入排序(簡(jiǎn)單插入排序)

3.1算法思想

如果有一個(gè)已經(jīng)有序的數(shù)據(jù)序列,要求在這個(gè)已經(jīng)排好的數(shù)據(jù)序列中插入一個(gè)數(shù),但要求插入后此數(shù)據(jù)序列仍然有序,這個(gè)時(shí)候就要用到一種新的排序方法——插入排序法,插入排序的基本操作就是將一個(gè)數(shù)據(jù)插入到已經(jīng)排好序的有序數(shù)據(jù)中,從而得到一個(gè)新的、長(zhǎng)度增加1的有序數(shù)據(jù)。

插入排序的基本思想是:每步將一個(gè)待排序的記錄,按其關(guān)鍵碼值的大小插入前面已經(jīng)排序的文件中適當(dāng)位置上,直到全部插入完為止。

同樣,這個(gè)算法不需要額外的存儲(chǔ)空間,空間復(fù)雜度為o(1),時(shí)間復(fù)雜度為o(n^2)

3.2算法過(guò)程

  1. 從第一個(gè)元素開始,該元素可以認(rèn)為已經(jīng)被排序;
  2. 取出下一個(gè)元素,在已經(jīng)排序的元素序列中從后向前掃描;
  3. 如果該元素(已排序)大于新元素,將該元素移到下一位置;
  4. 重復(fù)步驟3,直到找到已排序的元素小于或者等于新元素的位置;
  5. 將新元素插入到該位置后;
  6. 重復(fù)步驟2~5。直到排完序?yàn)橹埂?

3.3 python實(shí)現(xiàn)

            
              
                def
              
              
                insertionSort
              
              
                (
              
              numList
              
                )
              
              
                :
              
              
    n 
              
                =
              
              
                len
              
              
                (
              
              numList
              
                )
              
              
                if
              
               n 
              
                ==
              
              
                0
              
              
                or
              
               n 
              
                ==
              
              
                1
              
              
                :
              
              
                return
              
               numList
    
              
                for
              
               i 
              
                in
              
              
                range
              
              
                (
              
              n
              
                )
              
              
                :
              
              
        preIndex 
              
                =
              
               i 
              
                -
              
              
                1
              
              
        current 
              
                =
              
               numList
              
                [
              
              i
              
                ]
              
              
                while
              
               preIndex 
              
                >=
              
              
                0
              
              
                and
              
               current 
              
                <
              
               numList
              
                [
              
              preIndex
              
                ]
              
              
                :
              
              
            numList
              
                [
              
              preIndex
              
                +
              
              
                1
              
              
                ]
              
              
                =
              
               numList
              
                [
              
              preIndex
              
                ]
              
              
            preIndex 
              
                -=
              
              
                1
              
              
        numList
              
                [
              
              preIndex
              
                +
              
              
                1
              
              
                ]
              
              
                =
              
               current
    
              
                return
              
               numList
numlist 
              
                =
              
              
                [
              
              
                5
              
              
                ,
              
              
                3
              
              
                ,
              
              
                2
              
              
                ,
              
              
                1
              
              
                ,
              
              
                6
              
              
                ,
              
              
                8
              
              
                ,
              
              
                4
              
              
                ,
              
              
                2
              
              
                ,
              
              
                6
              
              
                ]
              
              
                print
              
              
                (
              
              insertionSort
              
                (
              
              numlist
              
                )
              
              
                )
              
              
                # 輸出結(jié)果為:[1, 2, 2, 3, 4, 5, 6, 6, 8]
              
            
          

更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對(duì)您有幫助就好】

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長(zhǎng)會(huì)非常 感謝您的哦!!!

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論
主站蜘蛛池模板: 延安市| 特克斯县| 扬中市| 大宁县| 长葛市| 固安县| 沙田区| 汉源县| 宣恩县| 鹤壁市| 阳谷县| 乐山市| 嘉黎县| 冀州市| 繁昌县| 杨浦区| 侯马市| 惠来县| 乌兰浩特市| 上高县| 泸州市| 金湖县| 白水县| 亚东县| 阿城市| 安化县| 茂名市| 镇安县| 临城县| 杭锦后旗| 延吉市| 陇川县| 尼木县| 宜阳县| 连平县| 岳西县| 台东市| 淅川县| 克什克腾旗| 阿荣旗| 湘乡市|