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

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

python實現經典排序算法的示例代碼

瀏覽:86日期:2022-06-28 10:19:08

以下排序算法最終結果都默認為升序排列,實現簡單,沒有考慮特殊情況,實現僅表達了算法的基本思想。

冒泡排序

內層循環中相鄰的元素被依次比較,內層循環第一次結束后會將最大的元素移到序列最右邊,第二次結束后會將次大的元素移到最大元素的左邊,每次內層循環結束都會將一個元素排好序。

def bubble_sort(arr): length = len(arr) for i in range(length): for j in range(length - i - 1): if arr[j] > arr[j + 1]:arr[j], arr[j + 1] = arr[j + 1], arr[j] return arr選擇排序

每次內層循環都會得到一個當前最小的元素,并將其放到合適的位置。內層循環第一次結束后會將最小的元素交換到序列首位,第二次結束后會將第二小的元素交換到序列第二位,每次內層循環結束后都會將一個元素放在正確的順序位置。

def selection_sort(arr): length = len(arr) for i in range(length): min_index = i for j in range(i + 1, length): if arr[j] < arr[min_index]:min_index = j arr[i], arr[min_index] = arr[min_index], arr[i] return arr插入排序

類比玩撲克牌時理牌的思想,從第一個元素開始,假設它是已經排好序的。然后開始處理第二個元素,如果比第一個元素小,則將其放到第一個元素左邊,否則放在其右邊,那么現在前兩個元素以及排好序了,之后再依次處理剩余的元素。

def insertion_sort(arr): length = len(arr) for i in range(1, length): pre = i - 1 current_value = arr[i] while pre >= 0 and arr[pre] > current_value: arr[pre + 1] = arr[pre] pre -= 1 arr[pre+1] = current_value return arr希爾排序

希爾排序就是將插入排序的改進版本。插入排序中每次逐步比較元素,而希爾排序中則是從一個較大的步數開始比較,最后減小到一步。

def shell_sort(arr): length = len(arr) gap = length // 2 while gap > 0: for i in range(gap, length): pre = i - gap current_value = arr[i] while pre >= 0 and arr[pre] > current_value:arr[pre + gap] = arr[pre]pre -= gap arr[pre + gap] = current_value gap = gap // 2 return arr歸并排序

先將序列前半部分排好序,再將序列后半部分排好序,之后再將這兩部分合并得到最終的序列,具體實現為遞歸地將序列分為兩部分,分別排序后再合并。

def merge(left, right): result = [] while len(left) > 0 and len(right) > 0: if left[0] < right[0]: result.append(left.pop(0)) else: result.append(right.pop(0)) if len(left) > 0: result.extend(left[:]) if len(right) > 0: result.extend(right[:]) return resultdef merge_sort(arr): if len(arr) < 2: return arr middle = len(arr) // 2 return merge(merge_sort(arr[:middle]), merge_sort(arr[middle:]))快速排序

取一個元素,將比它小的元素都移到它左側,將比它大的元素都移到它右側,并遞歸地處理它左側的序列和右側的序列。

def partition(arr, left=None, right=None): pivot = left index = pivot + 1 for i in range(index, right + 1): if arr[i] < arr[pivot]: arr[i], arr[index] = arr[index], arr[i] index += 1 arr[pivot], arr[index - 1] = arr[index - 1], arr[pivot] return index - 1def quick_sort(arr, left=None, right=None): left = 0 if left is None else left right = len(arr) - 1 if right is None else right if left < right: partition_index = partition(arr, left, right) quick_sort(arr, left, partition_index - 1) quick_sort(arr, partition_index + 1, right) return arr堆排序

首先構建一個最大堆,最大堆的性質是父節點的值總是大于其左右子節點的值,那么此時根節點的值是最大的,則將其移到序列的最右邊。之后將堆中當前最后一個葉節點移到根節點上,因為這可能會不符合最大堆的性質,所以會進行調整,將它與其左右子節點中最大的值進行交換,則相當于將葉節點向下移動,交換過后如果還是不符合性質,則繼續進行交換,直到符合性質后,此時的根節點的值就是當前堆中的最大值,將其取出放入序列中正確的位置后繼續上述流程處理剩下的節點。

global length2def heapify(arr, i): left = 2 * i + 1 right = 2 * i + 2 largest = i if left < length2 and arr[left] > arr[largest]: largest = left if right < length2 and arr[right] > arr[largest]: largest = right if largest != i: arr[i], arr[largest] = arr[largest], arr[i] heapify(arr, largest)def build_max_heap(arr): for i in range(len(arr) // 2, -1, -1): heapify(arr, i)def heap_sort(arr): global length2 length2 = len(arr) build_max_heap(arr) for i in range(len(arr) - 1, 0, -1): arr[0], arr[i] = arr[i], arr[0] length2 -= 1 heapify(arr, 0) return arr計數排序

將序列中的元素按照其值放入相應的桶中,之后再按照桶的順序取出即可,計數排序不需要比較操作。

def counting_sort(arr): max_value = max(arr) buckets = [0] * (max_value + 1) index = 0 length = len(arr) for i in range(length): buckets[arr[i]] += 1 for j in range(max_value + 1): while buckets[j] > 0: arr[index] = j index += 1 buckets[j] -= 1 return arr桶排序

類別計數排序,構造很多桶,但每個桶中能放入值在特定范圍內的元素,將序列中的元素按照要求放入各個桶中,再將每個桶中的元素進行排序,最后按照桶的順序和各個桶中元素的順序得到最終序列。

def bucket_sort(arr): bucket_size = 5 max_value = max(arr) min_value = min(arr) bucket_num = (max_value - min_value) // bucket_size + 1 buckets = {i: [] for i in range(bucket_num)} for i in range(len(arr)): buckets[(arr[i] - min_value) // bucket_size].append(arr[i]) result = [] for i in range(bucket_num): insertion_sort(buckets[i]) result.extend(buckets[i]) return result基數排序

按照元素值的特定位進行排序,從低位到高位分別進行排序。

def radix_sort(arr): max_value = max(arr) max_digit = len(str(max_value)) dev = 1 mod = 10 result = arr[:] for i in range(max_digit): buckets = {i: [] for i in range(mod)} for k in range(len(result)): key = (result[k] % mod) // dev buckets[key].append(result[k]) result = [] for j in range(mod): result.extend(buckets[j]) dev *= 10 mod *= 10 return result

上述代碼放在 這里

參考 https://www.cnblogs.com/onepixel/p/7674659.html 算法導論 菜鳥教程

到此這篇關于python實現經典排序算法的示例代碼的文章就介紹到這了,更多相關python 經典排序算法內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 钢格板|镀锌钢格板|热镀锌钢格板|格栅板|钢格板|钢格栅板|热浸锌钢格板|平台钢格板|镀锌钢格栅板|热镀锌钢格栅板|平台钢格栅板|不锈钢钢格栅板 - 专业钢格板厂家 | 杭州画室_十大画室_白墙画室_杭州美术培训_国美附中培训_附中考前培训_升学率高的画室_美术中考集训美术高考集训基地 | 上海瑶恒实业有限公司|消防泵泵|离心泵|官网 | 济南货架定做_仓储货架生产厂_重型货架厂_仓库货架批发_济南启力仓储设备有限公司 | 工业车间焊接-整体|集中除尘设备-激光|等离子切割机配套除尘-粉尘烟尘净化治理厂家-山东美蓝环保科技有限公司 | 影像测量仪_三坐标测量机_一键式二次元_全自动影像测量仪-广东妙机精密科技股份有限公司 | nalgene洗瓶,nalgene量筒,nalgene窄口瓶,nalgene放水口大瓶,浙江省nalgene代理-杭州雷琪实验器材有限公司 | 范秘书_懂你的范文小秘书| 企典软件一站式企业管理平台,可私有、本地化部署!在线CRM客户关系管理系统|移动办公OA管理系统|HR人事管理系统|人力 | 大_小鼠elisa试剂盒-植物_人Elisa试剂盒-PCR荧光定量试剂盒-上海一研生物科技有限公司 | 海尔生物医疗四川代理商,海尔低温冰箱四川销售-成都壹科医疗器械有限公司 | 中式装修设计_室内中式装修_【云臻轩】中式设计机构 | 浴室柜-浴室镜厂家-YINAISI · 意大利设计师品牌 | 咿耐斯 |-浙江台州市丰源卫浴有限公司 | 儿童乐园|游乐场|淘气堡招商加盟|室内儿童游乐园配套设备|生产厂家|开心哈乐儿童乐园 | 道达尔润滑油-食品级润滑油-道达尔导热油-合成导热油,深圳道达尔代理商合-深圳浩方正大官网 | 集装箱箱号识别_自重载重图像识别_铁路车号自动识别_OCR图像识别 | 数控车床-立式加工中心-多功能机床-小型车床-山东临沂金星机床有限公司 | 美侍宠物-专注宠物狗及宠物猫训练|喂养|医疗|繁育|品种|价格 | 全自动在线分板机_铣刀式在线分板机_曲线分板机_PCB分板机-东莞市亿协自动化设备有限公司 | 水厂自动化-水厂控制系统-泵站自动化|控制系统-闸门自动化控制-济南华通中控科技有限公司 | 长沙中央空调维修,中央空调清洗维保,空气能热水工程,价格,公司就找维小保-湖南维小保环保科技有限公司 | 广东之窗网 | U拓留学雅思一站式服务中心_留学申请_雅思托福培训 | 螺旋绞龙叶片,螺旋输送机厂家,山东螺旋输送机-淄博长江机械制造有限公司 | 控显科技 - 工控一体机、工业显示器、工业平板电脑源头厂家 | 电气控制系统集成商-PLC控制柜变频控制柜-非标自动化定制-电气控制柜成套-NIDEC CT变频器-威肯自动化控制 | 定量包装机,颗粒定量包装机,粉剂定量包装机,背封颗粒包装机,定量灌装机-上海铸衡电子科技有限公司 | 防勒索软件_数据防泄密_Trellix(原McAfee)核心代理商_Trellix(原Fireeye)售后-广州文智信息科技有限公司 | 优秀的临床医学知识库,临床知识库,医疗知识库,满足电子病历四级要求,免费试用 | 盘扣式脚手架-附着式升降脚手架-移动脚手架,专ye承包服务商 - 苏州安踏脚手架工程有限公司 | 生产自动包装秤_颗粒包装秤_肥料包装秤等包装机械-郑州鑫晟重工科技有限公司 | 商用绞肉机-熟肉切片机-冻肉切丁机-猪肉开条机 - 广州市正盈机械设备有限公司 | 广州工业氧气-工业氩气-工业氮气-二氧化碳-广州市番禺区得力气体经营部 | 武汉天安盾电子设备有限公司 - 安盾安检,武汉安检门,武汉安检机,武汉金属探测器,武汉测温安检门,武汉X光行李安检机,武汉防爆罐,武汉车底安全检查,武汉液体探测仪,武汉安检防爆设备 | 烟雾净化器-滤筒除尘器-防爆除尘器-除尘器厂家-东莞执信环保科技有限公司 | 科昊仪器超纯水机系统-可成气相液氮罐-美菱超低温冰箱-西安昊兴生物科技有限公司 | 聚合氯化铝-碱式氯化铝-聚合硫酸铁-聚氯化铝铁生产厂家多少钱一吨-聚丙烯酰胺价格_河南浩博净水材料有限公司 | 珠海冷却塔降噪维修_冷却塔改造报价_凉水塔风机维修厂家- 广东康明节能空调有限公司 | 高低温万能试验机_拉力试验机_拉伸试验机-馥勒仪器科技(上海)有限公司 | 钛合金标准件-钛合金螺丝-钛管件-钛合金棒-钛合金板-钛合金锻件-宝鸡远航钛业有限公司 | 卡诺亚轻高定官网_卧室系统_整家定制_定制家居_高端定制_全屋定制加盟_定制家具加盟_定制衣柜加盟 |