久久精品国产亚洲高清|精品日韩中文乱码在线|亚洲va中文字幕无码久|伊人久久综合狼伊人久久|亚洲不卡av不卡一区二区|精品久久久久久久蜜臀AV|国产精品19久久久久久不卡|国产男女猛烈视频在线观看麻豆

    1. <style id="76ofp"></style>

      <style id="76ofp"></style>
      <rt id="76ofp"></rt>
      <form id="76ofp"><optgroup id="76ofp"></optgroup></form>
      1. 千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

        手機(jī)站
        千鋒教育

        千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

        千鋒教育

        掃一掃進(jìn)入千鋒手機(jī)站

        領(lǐng)取全套視頻
        千鋒教育

        關(guān)注千鋒學(xué)習(xí)站小程序
        隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

        當(dāng)前位置:首頁(yè)  >  技術(shù)干貨  > PythonSort:程序優(yōu)化中的利器

        PythonSort:程序優(yōu)化中的利器

        來源:千鋒教育
        發(fā)布人:xqq
        時(shí)間: 2023-07-21 16:54:33 1689929673

        一、排序算法概述

        排序算法是程序中常用的一種基礎(chǔ)算法,它可以對(duì)數(shù)據(jù)集合進(jìn)行排序,使得其滿足某種有序性,方便后續(xù)的數(shù)據(jù)處理。常用的排序算法包括冒泡排序、插入排序、選擇排序、歸并排序、快速排序、堆排序等。

        這些算法各有千秋,不同算法適用于不同的應(yīng)用場(chǎng)景,比如數(shù)據(jù)集合大小、數(shù)據(jù)分布規(guī)律等因素會(huì)影響算法的效率。因此,我們需要在實(shí)際應(yīng)用中靈活選擇合適的排序算法。

        二、Python中的排序函數(shù)

        Python語(yǔ)言內(nèi)置了排序函數(shù)sorted()和sort(),可以方便地對(duì)列表等數(shù)據(jù)集合進(jìn)行排序,其中sort()在原地排序,sorted()返回一個(gè)新的排好序的列表。這兩個(gè)函數(shù)都可以接受key、reverse參數(shù),用于自定義排序方式。

        
        #示例代碼
        #對(duì)列表a進(jìn)行從小到大的排序
        a = [2, 1, 3]
        sorted_a = sorted(a)
        print(sorted_a)  # 輸出[1, 2, 3]
        
        #對(duì)列表a進(jìn)行從大到小的排序
        a.sort(reverse=True)
        print(a)  # 輸出[3, 2, 1]
        
        #對(duì)字典d按值的大小進(jìn)行排序
        d = {'a': 2, 'b': 1, 'c': 3}
        sorted_d = sorted(d.items(), key=lambda x: x[1])
        print(sorted_d)  # 輸出[('b', 1), ('a', 2), ('c', 3)]
        

        三、常用排序算法的實(shí)現(xiàn)

        1. 冒泡排序

        冒泡排序是一種簡(jiǎn)單的交換排序,基本思想是重復(fù)地走訪過要排序的數(shù)列,每次比較兩個(gè)相鄰的元素,如果它們的順序錯(cuò)誤就交換它們的位置。其時(shí)間復(fù)雜度為O(n^2)。

        
        #示例代碼
        def bubble_sort(arr):
            n = len(arr)
            for i in range(n):
                for j in range(n-i-1):
                    if arr[j] > arr[j+1]:
                        arr[j], arr[j+1] = arr[j+1], arr[j]
        
        arr = [2, 1, 3]
        bubble_sort(arr)
        print(arr)  # 輸出[1, 2, 3]
        
        

        2. 快速排序

        快速排序是一種分治迭代的排序算法,基本思想是把原數(shù)列分成兩部分,一部分比另一部分所有元素都要小,再分別對(duì)這兩部分遞歸地進(jìn)行快速排序。其時(shí)間復(fù)雜度一般為O(nlogn),具體取決于選取的分割點(diǎn)。

        
        #示例代碼
        def quick_sort(arr):
            if not arr:
                return []
            else:
                pivot = arr[0]
                left = [x for x in arr[1:] if x < pivot]
                right = [x for x in arr[1:] if x >= pivot]
                return quick_sort(left) + [pivot] + quick_sort(right)
        
        arr = [2, 1, 3]
        sorted_arr = quick_sort(arr)
        print(sorted_arr)  # 輸出[1, 2, 3]
        
        

        3. 歸并排序

        歸并排序是一種分治迭代的排序算法,基本思想是把原數(shù)列分成若干個(gè)小的數(shù)列,再將這些小的數(shù)列合并成較大的有序數(shù)列,最終合并成一個(gè)有序數(shù)列。其時(shí)間復(fù)雜度一般為O(nlogn),具體取決于合并方式。

        
        #示例代碼
        def merge_sort(arr):
            if len(arr) <= 1:
                return arr
            mid = len(arr) // 2
            left = arr[:mid]
            right = arr[mid:]
            left = merge_sort(left)
            right = merge_sort(right)
            return merge(left, right)
        
        def merge(left, right):
            res = []
            i = 0
            j = 0
            while i < len(left) and j < len(right):
                if left[i] <= right[j]:
                    res.append(left[i])
                    i += 1
                else:
                    res.append(right[j])
                    j += 1
            res += left[i:]
            res += right[j:]
            return res
        
        arr = [2, 1, 3]
        sorted_arr = merge_sort(arr)
        print(sorted_arr)  # 輸出[1, 2, 3]
        
        

        四、排序算法的性能比較

        各種排序算法的性能取決于不同的因素,比如數(shù)據(jù)規(guī)模、數(shù)據(jù)分布情況等。下面分別對(duì)三種排序算法進(jìn)行測(cè)試,比較它們的排序效率。

        
        #示例代碼
        import random
        import time
        
        def test_bubble_sort():
            arr = list(range(10000))
            random.shuffle(arr)
            start_time = time.time()
            bubble_sort(arr)
            end_time = time.time()
            print('bubble sort cost time:', end_time - start_time)
        
        def test_quick_sort():
            arr = list(range(10000))
            random.shuffle(arr)
            start_time = time.time()
            quick_sort(arr)
            end_time = time.time()
            print('quick sort cost time:', end_time - start_time)
        
        def test_merge_sort():
            arr = list(range(10000))
            random.shuffle(arr)
            start_time = time.time()
            merge_sort(arr)
            end_time = time.time()
            print('merge sort cost time:', end_time - start_time)
        
        test_bubble_sort()
        test_quick_sort()
        test_merge_sort()
        

        運(yùn)行結(jié)果如下:

        
        bubble sort cost time: 8.834352970123291
        quick sort cost time: 0.008945941925048828
        merge sort cost time: 0.014842033386230469
        

        可以看到,在數(shù)據(jù)量較大的情況下,冒泡排序的效率明顯低于快速排序和歸并排序。

        五、總結(jié)

        排序算法是一種常用的基礎(chǔ)算法,Python語(yǔ)言內(nèi)置了排序函數(shù),同時(shí)我們也可以利用Python靈活地實(shí)現(xiàn)各種排序算法,并根據(jù)實(shí)際應(yīng)用需求進(jìn)行選擇。

        在實(shí)際應(yīng)用中,不同的排序算法適用于不同的數(shù)據(jù)集合規(guī)模和問題規(guī)模,在我們對(duì)排序算法進(jìn)行性能測(cè)試的過程中,快速排序和歸并排序的效率較高,尤其適用于大規(guī)模數(shù)據(jù)集合的排序。

        tags: python教程
        聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
        10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
        請(qǐng)您保持通訊暢通,專屬學(xué)習(xí)老師24小時(shí)內(nèi)將與您1V1溝通
        免費(fèi)領(lǐng)取
        今日已有369人領(lǐng)取成功
        劉同學(xué) 138****2860 剛剛成功領(lǐng)取
        王同學(xué) 131****2015 剛剛成功領(lǐng)取
        張同學(xué) 133****4652 剛剛成功領(lǐng)取
        李同學(xué) 135****8607 剛剛成功領(lǐng)取
        楊同學(xué) 132****5667 剛剛成功領(lǐng)取
        岳同學(xué) 134****6652 剛剛成功領(lǐng)取
        梁同學(xué) 157****2950 剛剛成功領(lǐng)取
        劉同學(xué) 189****1015 剛剛成功領(lǐng)取
        張同學(xué) 155****4678 剛剛成功領(lǐng)取
        鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
        董同學(xué) 138****2867 剛剛成功領(lǐng)取
        周同學(xué) 136****3602 剛剛成功領(lǐng)取
        相關(guān)推薦HOT
        為什么Hadoop是用Java實(shí)現(xiàn)的?

        一、跨平臺(tái)能力多平臺(tái)運(yùn)行:Java的“一次編寫,到處運(yùn)行”理念,使得Hadoop能在各種操作系統(tǒng)和硬件上運(yùn)行,不需要特定的調(diào)整。廣泛應(yīng)用:這一特...詳情>>

        2023-10-15 16:51:37
        ECU是什么?

        1、ECU的基本定義與作用ECU,全稱為電子控制單元,是一種專門用于控制汽車各個(gè)系統(tǒng)的微處理器控制系統(tǒng)。通過接收傳感器的信號(hào)并轉(zhuǎn)換成控制指令...詳情>>

        2023-10-15 16:29:54
        什么是SOA?

        1、SOA的基本概念與核心原則SOA是一種使軟件組件通過網(wǎng)絡(luò)進(jìn)行互操作的架構(gòu)模式。核心原則包括:可發(fā)現(xiàn)的服務(wù):服務(wù)應(yīng)容易發(fā)現(xiàn)和理解。松耦合:...詳情>>

        2023-10-15 16:19:32
        什么是內(nèi)存池?

        1、內(nèi)存池的基本概念內(nèi)存池是一種內(nèi)存管理策略,旨在優(yōu)化內(nèi)存分配性能和減少碎片化。通過將內(nèi)存分配到大小固定的池中,應(yīng)用程序可以快速、高效...詳情>>

        2023-10-15 16:16:15
        ci構(gòu)建與編譯的區(qū)別是什么?

        一、功能與目的構(gòu)建(Build): 構(gòu)建是將源代碼轉(zhuǎn)化為可執(zhí)行代碼的過程,它包括編譯、鏈接、打包等一系列步驟。構(gòu)建不僅僅局限于編譯,還可能涉...詳情>>

        2023-10-15 15:57:11
        快速通道
        利辛县| 子长县| 栾川县| 丽水市| 衡东县| 凤凰县| 曲周县| 察隅县| 永寿县| 芜湖市| 凉城县| 朝阳区| 沽源县| 泰兴市| 类乌齐县| 纳雍县| 武义县| 浏阳市| 马龙县| 青铜峡市| 信丰县| 镇康县| 龙海市| 青海省| 普安县| 阿瓦提县| 隆子县| 石家庄市| 舞钢市| 衢州市| 永川市| 兴化市| 女性| 社旗县| 台北县| 类乌齐县| 揭西县| 崇礼县| 宣汉县| 巫溪县| 南华县|