电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

深入分析python 排序

瀏覽:5日期:2022-07-13 11:36:44

排序是每個開發人員都需要掌握的技能。排序是對程序本身有一個全面的理解。不同的排序算法很好地展示了算法設計上如何強烈的影響程序的復雜度、運行速度和效率。今天的文章和談談大家都熟悉的各種排序使用 Python 如何實現,廢話就不多說啦,開干!

選擇排序

選擇排序一般是將初始值設為初始值,再循環后面每個元素與第一個元素比較,最終篩選出一個最小或最大值,最后將有序的數值排在前面,每次選擇當前序列的最小值,將其與當前序列的第一個元素交換位置,每迭代一次,當前序列長度減一。迭代結束,即可得到有序序列。 實現代碼如下:

def select_s(data): # 第一層循環:取出數組中的每個元素 for i in range(len(data)): temp = i # 拿取一個元素用來比較 # 第二層循環:從第i后面的一個值開始循環,與data[i]進行比較 for j in range(i+1,len(data)): if data[j] < data[temp]:data[temp], data[j] = data[j], data[temp] print(data)

調用運行結果:

if __name__ == ’__main__’: data = [14, 31, 14, 6, 18, 24, 2, 40] select_s(data)

輸出結果:

[2, 6, 14, 14, 18, 24, 31, 40]

插入排序

插入排序的基本操作就是將一個數據插入到已經排好序的有序數據中,從而得到一個新的、個數加一的有序數據,算法適用于少量數據的排序,時間復雜度為O(n^2)。是穩定的排序方法。

插入算法把要排序的數組分成兩部分:第一部分包含了這個數組的所有元素,但將最后一個元素除外(讓數組多一個空間才有插入的位置),而第二部分就只包含這一個元素(即待插入元素)。在第一部分排序完成后,再將這個最后元素插入到已排好序的第一部分中。

深入分析python 排序

實現代碼如下:

def insert_s(data): # 第一層循環: 從第二個元素開始循環取出元素,取出的元素再與有序區元素進行比較 for i in range(1,len(data)): temp = data[i] j = i-1 while j>=0 and temp < data[j]: data[j+1] = data[j]j = j-1 # 在與前面一個元素進行比較,所以j 需要減1 # 當j = -1 就跳出循環,將temp值賦給第一個值,即data[0] data[j+1] = temp print(data)

調用運行結果:

if __name__ == ’__main__’:data = [12, 3, 13, 56, 10, 22, 2, 40]insert_s(data)

輸出結果:

[2, 3, 10, 12, 13, 22, 40, 56]

冒泡排序

冒泡排序(順序形式),從左向右,兩兩比較,如果左邊元素大于右邊,就交換兩個元素的位置。

其中,每一輪排序,序列中最大的元素浮動到最右面。也就是說,每一輪排序,至少確保有一個元素在正確的位置。

這樣接下來的循環,就不需要考慮已經排好序的元素了,每次內層循環次數都會減一。

其中,如果有一輪循環之后,次序并沒有交換,這時我們就可以停止循環,得到我們想要的有序序列了。

深入分析python 排序

def insert_s(data): # 第一層循環: 從第二個元素開始循環取出元素,取出的元素再與有序區元素進行比較 for i in range(1,len(data)): temp = data[i] j = i-1 while j>=0 and temp < data[j]: data[j+1] = data[j]j = j-1 # 在與前面一個元素進行比較,所以j 需要減1 # 當j = -1 就跳出循環,將temp值賦給第一個值,即data[0] data[j+1] = temp print(data)

調用運行結果:

if __name__ == ’__main__’: data = [12, 3, 13, 56, 10, 22, 2, 40] insert_s(data)

輸出結果:

[2, 3, 10, 12, 13, 22, 40, 56]

快速排序

首先要打亂序列順序,以防算法陷入最壞時間復雜度。所以快速排序使用 “分而治之” 的方法。

對于一串序列,首先從中選取一個數,凡是小于這個數的值就被放在左邊,凡是大于這個數的值就被放在右邊。然后,繼續對左右兩摞進行快速排序。

直到進行快速排序的序列長度小于 2 (即序列中只有一個值或者空值)。

深入分析python 排序

代碼如下:

# 快速排序def partition(data, left, right): temp = data[left] while left < right: # 如果最右邊的值大于中間值,則最右邊值往后退一個位置,反之,就將值賦值給最左邊位置 while left < right and data[right] >= temp: right = right - 1 data[left] = data[right] # 如果最左邊的值小于中間值,則最左邊值往前進一個位置,反之,就將值賦值給最右邊位置 while left < right and data[left] <= temp: left = left + 1 data[right] = data[left] # 循環結束,即可定位到中間位置,將初始值,賦值到這個位置 data[left] = temp return leftdef quick_sort(data, left, right): if left < right: mid = partition(data, left, right) quick_sort(data, left, mid) quick_sort(data, mid + 1, right)

總結

今天的文章主要是使用 Python 實現各大排序程序,以及排序算法實現思路的梳理,自己學習的同時給大家整理思路!

示例代碼Python 排序了解一下?

以上就是深入分析python 排序的詳細內容,更多關于python 排序的資料請關注好吧啦網其它相關文章!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 浙江华锤电器有限公司_地磅称重设备_防作弊地磅_浙江地磅售后维修_无人值守扫码过磅系统_浙江源头地磅厂家_浙江工厂直营地磅 | 带式压滤机_污泥压滤机_污泥脱水机_带式过滤机_带式压滤机厂家-河南恒磊环保设备有限公司 | 顶空进样器-吹扫捕集仪-热脱附仪-二次热解吸仪-北京华盛谱信仪器 | 吹田功率计-长创耐压测试仪-深圳市新朗普电子科技有限公司 | 气动|电动调节阀|球阀|蝶阀-自力式调节阀-上海渠工阀门管道工程有限公司 | 「安徽双凯」自动售货机-无人售货机-成人用品-自动饮料食品零食售货机 | 超声波反应釜【百科】-以马内利仪器 | 长沙一级消防工程公司_智能化弱电_机电安装_亮化工程专业施工承包_湖南公共安全工程有限公司 | 自动记录数据电子台秤,记忆储存重量电子桌称,设定时间记录电子秤-昆山巨天 | 全自动贴标机-套标机-工业热风机-不干胶贴标机-上海厚冉机械 | TPM咨询,精益生产管理,5S,6S现场管理培训_华谋咨询公司 | 蓄电池回收,ups电池后备电源回收,铅酸蓄电池回收,机房电源回收-广州益夫铅酸电池回收公司 | 气动隔膜泵-电动隔膜泵-循环热水泵-液下排污/螺杆/管道/化工泵「厂家」浙江绿邦 | 电抗器-能曼电气-电抗器专业制造商| 本安接线盒-本安电路用接线盒-本安分线盒-矿用电话接线盒-JHH生产厂家-宁波龙亿电子科技有限公司 | 耐力板-PC阳光板-PC板-PC耐力板 - 嘉兴赢创实业有限公司 | 证券新闻,热播美式保罗1984第二部_腾讯1080p-仁爱影院 | 小青瓦丨古建筑瓦丨青瓦厂家-宜兴市徽派古典建筑材料有限公司 | 不锈钢复合板|钛复合板|金属复合板|南钢集团安徽金元素复合材料有限公司-官网 | 浙江华锤电器有限公司_地磅称重设备_防作弊地磅_浙江地磅售后维修_无人值守扫码过磅系统_浙江源头地磅厂家_浙江工厂直营地磅 | 对辊破碎机-液压双辊式,强力双齿辊,四辊破碎机价格_巩义市金联机械设备生产厂家 | 加热制冷恒温循环器-加热制冷循环油浴-杭州庚雨仪器有限公司 | 氧化铁红厂家-淄博宗昂化工 | 广州展览制作工厂—[优简]直营展台制作工厂_展会搭建资质齐全 | 北京发电机出租_发电机租赁_北京发电机维修 - 河北腾伦发电机出租 | 液压油缸-液压缸厂家价格,液压站系统-山东国立液压制造有限公司 液压油缸生产厂家-山东液压站-济南捷兴液压机电设备有限公司 | 二手Sciex液质联用仪-岛津气质联用仪-二手安捷伦气质联用仪-上海隐智科学仪器有限公司 | 广西绿桂涂料--承接隔热涂料、隔音涂料、真石漆、多彩仿石漆等涂料工程双包施工 | 探鸣起名网-品牌起名-英文商标起名-公司命名-企业取名包满意 | 珠光砂保温板-一体化保温板-有釉面发泡陶瓷保温板-杭州一体化建筑材料 | 健康管理师报考条件,考试时间,报名入口—首页 | 挤出熔体泵_高温熔体泵_熔体出料泵_郑州海科熔体泵有限公司 | 模具钢_高速钢_不锈钢-万利钢金属材料| 贵州成人高考网_贵州成考网| 耐火浇注料价格-高强高铝-刚玉碳化硅耐磨浇注料厂家【直销】 | 合肥白癜风医院_[治疗白癜风]哪家好_合肥北大白癜风医院 | 披萨石_披萨盘_电器家电隔热绵加工定制_佛山市南海区西樵南方综合保温材料厂 | 免联考国际MBA_在职MBA报考条件/科目/排名-MBA信息网 | 微波消解仪器_智能微波消解仪报价_高压微波消解仪厂家_那艾 | 消防泵-XBD单级卧式/立式消防泵-上海塑泉泵阀(集团)有限公司 | 无锡网站建设_小程序制作_网站设计公司_无锡网络公司_网站制作 |