《常見排序演算法--PHP實現》

来源:https://www.cnblogs.com/aiweixiao/archive/2018/01/05/8202360.html
-Advertisement-
Play Games

原文地址: 本文地址:http://www.cnblogs.com/aiweixiao/p/8202360.html Original 2018-01-02 關註 微信公眾號 程式員的文娛情懷 1.概述 常見的排序演算法,雖然很基礎,但是很見功力,如果能思路清晰,很快寫出來各個演算法的代碼實現,還是需要 ...


原文地址

本文地址:http://www.cnblogs.com/aiweixiao/p/8202360.html

 

1.概述

    常見的排序演算法,雖然很基礎,但是很見功力,如果能思路清晰,很快寫出來各個演算法的代碼實現,還是需要花一點功夫的,今天,就跟大家盤點下常用的一些演算法。

冒泡排序

插入排序

選擇排序

希爾排序

堆排序

歸併排序

快速排序

 

2.各個排序代碼實現(PHP版本)

代碼詳見GitHub: http://t.cn/RHjBCU7

    2.1 冒泡排序


    1)【定義】:就是第一個位置上的數與他相鄰第二個位置上的數比較,如果比他相鄰的數小,則兩者交換位置,否則不交換。接著第一個位置上的數與第三個位置上的數比較大小,也是小則交換,一直到和最後一個位置的數比較交換完畢。然後,是下一個迴圈,就是第二個位置上的數重覆上面的比較交換操作,直到把整個數列變成是一個從小到大的有序序列。

 

    2)【代碼實現】:兩層for迴圈搞定。

  冒泡排序

2.2 插入排序


    1)【定義】:從一堆待排序的數列中選出來一個最小值(可以認為第一個數就是已排序的數列),然後從剩餘的帶排序的數列中選出來最小值有序放到已排序的數列中,依次操作,直到最後的數列都是一個從小到大的有序數列為止。

    2)【代碼實現】:

  插入排序

2.3 選擇排序


    1)【定義】: 從一堆待排序的數列中選出來一個最小值,放到新的數組的第一個位置,繼續從剩餘的數列中選取最小值放入到數組中,重覆上面的步驟,將數字都取出來排成新的有序數列。 

    2)【代碼實現】:

  選擇排序主函數

 

  選擇排序子函數

2.4 希爾排序


    1)【定義】: 插入排序的一種改進,先比較一定距離的元素成為有序數列,再比較縮小增量距離的元素(可為元素的數量的一半),一直到比較的是相鄰元素的時候,就成為了插入排序。所以希爾排序是插入排序的改進。

    2)【代碼實現】:

  希爾排序

2.5 堆排序


1)【定義】:1️⃣構造大頂堆 2️⃣交換堆頂和堆底 3️⃣重覆前面的步驟升序排列完成

    詳細說明參看: https://www.cnblogs.com/chengxiao/p/6129630.html

2)【代碼實現】

 

  堆排序主函數heapSort()

 

  堆排序子函數

2.6 歸併排序


    1)【定義】:就是將待排序的數列看成是單個的有序的數列,然後進行合併,直到合併成最後的完成整有序的數列。

    詳細可參考:https://www.cnblogs.com/jingmoxukong/p/4308823.html

    2)代碼實現:

    主函數mergeSort(),兩個子函數mergePass() 和 merge()

 

  歸併排序主函數mergeSort()

 

  歸併排序子函數mergePass()

 

  歸併排序子函數merge() 

 

2.7 快速排序


1)定義:該演算法的基本思想是:

    1.先從數列中取出一個數作為基準數。

    2.分區過程,將比這個數大的數全放到它的右邊,小於或等於它的數全放到它的左邊。

    3.再對左右區間重覆第二步,直到各區間只有一個數

2)代碼實現:

 

  快速排序

 

3.排序總結

各種排序的穩定性,時間複雜度、空間複雜度、穩定性總結如下圖:

 

  排序演算法比較

 

 

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • AMD是"Asynchronous Module Definition"的縮寫,意思就是"非同步模塊定義"。它採用非同步方式載入模塊,模塊的載入不影響它後面語句的運行。所有依賴這個模塊的語句,都定義在一個回調函數中,等到載入完成之後,這個回調函數才會運行。 ...
  • ajaxJson('POST', url, JSON.stringify(param), function(err, result){ //result or rsp // if(SUCCESS){ //....... }else{ //....... } }); ————————————————— ...
  • 本文地址:http://www.cnblogs.com/aiweixiao/p/8202365.html 原文地址: 歡迎關註微信公眾號 程式員的文娛情懷 一、主要內容: 1️⃣php擴展的概念和底層實現 2️⃣編寫一個php擴展的步驟 3️⃣php底層,Zend 引擎API的介紹 ,HashTab ...
  • A代碼編輯器,線上模版編輯,仿開發工具編輯器,pdf線上預覽,文件轉換編碼B 集成代碼生成器 [正反雙向](單表、主表、明細表、樹形表,快速開發利器)+快速表單構建器freemaker模版技術 ,0個代碼不用寫,生成完整的一個模塊,帶頁面、建表sql腳本,處理類,service等完整模塊C 集成阿裡 ...
  • nuget包也要自動化部署了,想想確實挺好,在實施過程中我們要解決的問題有版本自動控制,nuget自動打包,nuget自動上傳到服務端等。 一 參數化構建 二 環境變數的k/v參數,存儲類庫的初始版本,當根目錄version.txt生成後,這個k/v就不需要了 三 這個構建跳轉到哪台節點伺服器 四 ...
  • 架構師寫的軟體指南 《 程式員必讀之軟體架構 》筆記 語境 意圖 這個軟體項目/產品/系統是關於什麼的? 構建的是什麼? 它如何融入現有環境? 誰在使用? 功能性概覽 意圖 系統實際上做什麼? 哪些特性、功能、用例、用戶故事是重要的?原因? 重要用戶是誰?系統如何滿足他們的需求? 上述已經用於塑造和 ...
  • 高可用的兩大目的:數據備份,數據分片 1、FastDFS安裝配置 先配置一臺,將其中的配置文件打包,下載,然後配置其他機器時只需要解壓即可, 打包命令 然後下載,上傳到其他機器相對應的/etc目錄下 將其他機器中的fdfs文件夾刪除 解壓上傳文件 2、 伺服器列表 伺服器IP 組 角色 192.16 ...
  • 預覽數據 這次我們使用 Artworks.csv ,我們選取 100 行數據來完成本次內容。具體步驟: DataFrame 是 Pandas 內置的數據展示的結構,展示速度很快,通過 DataFrame 我們就可以快速的預覽和分析數據。代碼如下: 統計日期數據 我們仔細觀察一下 Date 列的數據, ...
一周排行
    -Advertisement-
    Play Games
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...