搜尋
首頁後端開發php教程php冒泡排序實例分享

php冒泡排序實例分享

Feb 27, 2018 am 11:24 AM
php分享實例

原理:對一組數據,比較相鄰數據的大小,將值小數據在前面,值大的數據放在後面。 (以下皆為升序排列,即從小到大排列)

  舉例說明: $arr = array(6, 3, 8, 2, 9, 1);

#   $ arr 有6個數據,依照兩兩比較大小如下,注意 比較輪數與每輪比較次數 

  第一輪排序:

    第一次比較 6與3比較結果:3 6   8   2   9   1     

    第二次比較 6與3比較結果:3    6   8    6   2   8   9   1 

    第四次比較 8與9比較結果:3    6   2   8   9   1 

  

#  第一輪比較總結:1.排序第1輪、比較5次,沒有獲得從小到大的排序  2.因為每次比較都是大數往後靠,所以比較完成後,可以確定大數排在最後( 9 冒泡冒出來了,下輪比較可以不用比較了 )

 

  第二輪排序:

    第一次比較 3和6比較結果: 3    6   2   8   1   9     

    第二次比較 6與2比較結果:3    與8比較結果:3    2   6   8   1   9

    第四次比較 8與1比較結果:3    2   6   1   8   9 

 

#  第二輪比較總結:1.

## 

》 ,沒有獲得從小到大的排序  2.冒泡出了8,下輪不用比較8 了

  第三輪排序:

    第一次比較 3和2比較結果:2 3   6   1   8   9     

    第二次比較 3與6比較結果:2    3   6〠 1結果:2    3   1   6   8   9 

  第三輪比較總結:1.排序第3輪、比較3次,沒有獲得從小到大的排序  2.冒泡出了6,下輪不用比較6 了

 

  第四輪排序:

    第一次比較 2與3比較結果:2    3   1   6   8  3   6   8   9 

  第四輪比較總結:1.排序第4輪、比較2次,沒有獲得從小到大的排序  2.冒泡出了3,下輪不用比較3 了

 

  第五輪排序:

##    第一次比較 2和1比較結果:1   2   3   6   8   9      3   6   8   9      3   6   8   9      5  .排序第5輪、比較1次,沒有獲得從小到大的排序  2.冒泡出了2,由於還剩一個1,不用再比較了,至此通過5輪排序,完成整個排序。

 

  經過以上五輪排序,若干次比較,我們有理由推論出一個結論:

  對於一個長度為N的數組,我們需要排序N-1輪,每i 輪要比較N-i 次。對此我們可以用雙重循環語句,外層循環控制循環輪次,內層循環控制每輪的比較次數。

<?php 

  function order($arr){
      $count = count($arr);
      $temp = 0; 
      //外层控制排序轮次
      for($i=0; $i<$count-1; $i++){
          //内层控制每轮比较次数
          for($j=0; $j< $count-1-$i; $j++){
                if($arr[$j] > $arr[$j+1]){
                    $temp        = $arr[$j];
                    $arr[$j]     = $arr[$j+1];
                    $arr[$j+1]   = $temp;
               }
          }
      } 
      return $arr;
     }     


 $arr= array(6,3,8,2,9,1);
$res =  order($arr);
var_dump($res);

相關推薦:

php實作冒泡排序多種方案

php冒泡排序之陣列從小到大排序方法

php陣列冒泡排序演算法實例代碼

以上是php冒泡排序實例分享的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
如何使PHP應用程序更快如何使PHP應用程序更快May 12, 2025 am 12:12 AM

tomakephpapplicationsfaster,關注台詞:1)useopcodeCachingLikeLikeLikeLikeLikePachetoStorePreciledScompiledScriptbyTecode.2)MinimimiedAtabaseSqueriSegrieSqueriSegeriSybysequeryCachingandeffeftExting.3)Leveragephp7 leveragephp7 leveragephp7 leveragephpphp7功能forbettercodeefficy.4)

PHP性能優化清單:立即提高速度PHP性能優化清單:立即提高速度May 12, 2025 am 12:07 AM

到ImprovephPapplicationspeed,關注台詞:1)啟用opcodeCachingwithapCutoredUcescriptexecutiontime.2)實現databasequerycachingingusingpdotominiminimizedatabasehits.3)usehttp/2tomultiplexrequlexrequestsandreduceconnection.4 limitesclection.4.4

PHP依賴注入:提高代碼可檢驗性PHP依賴注入:提高代碼可檢驗性May 12, 2025 am 12:03 AM

依赖注入(DI)通过显式传递依赖关系,显著提升了PHP代码的可测试性。1)DI解耦类与具体实现,使测试和维护更灵活。2)三种类型中,构造函数注入明确表达依赖,保持状态一致。3)使用DI容器管理复杂依赖,提升代码质量和开发效率。

PHP性能優化:數據庫查詢優化PHP性能優化:數據庫查詢優化May 12, 2025 am 12:02 AM

DatabasequeryoptimizationinPHPinvolvesseveralstrategiestoenhanceperformance.1)Selectonlynecessarycolumnstoreducedatatransfer.2)Useindexingtospeedupdataretrieval.3)Implementquerycachingtostoreresultsoffrequentqueries.4)Utilizepreparedstatementsforeffi

簡單指南:帶有PHP腳本的電子郵件發送簡單指南:帶有PHP腳本的電子郵件發送May 12, 2025 am 12:02 AM

phpisusedforsenderemailsduetoitsbuilt-inmail()函數andsupportivelibrariesLikePhpMailerAndSwiftMailer.1)usethemail()functionForbasiceMails,butithasimails.2)butithasimail.2)

PHP中的依賴注入:一個簡單的解釋PHP中的依賴注入:一個簡單的解釋May 10, 2025 am 12:08 AM

依賴性(di)inphpenhancesCodeFlexibility andTestability by decouplingClassesscyclasses fromtheippentencies.1)UseConstructorientoctionTopAssDopassDectiesViactructors Viactructors

PHP DI容器比較:選擇哪一個?PHP DI容器比較:選擇哪一個?May 10, 2025 am 12:07 AM

推薦Pimple用於簡單項目,Symfony的DependencyInjection用於復雜項目。 1)Pimple適合小型項目,因其簡單和靈活。 2)Symfony的DependencyInjection適合大型項目,因其功能強大。選擇時需考慮項目規模、性能需求和學習曲線。

PHP依賴注入:什麼,為什麼以及如何?PHP依賴注入:什麼,為什麼以及如何?May 10, 2025 am 12:06 AM

依賴性注射(DI)InphpisadesignpatternwhereClassDepentenciesArepassedtotosedTosedTosedTotratherThancReateDinterally,增強codemodemodularityAndTestabily.itimprovessoftwarequalitybyby By:1)增強tosestabilityTestabilityTestabilityThroughityThroughEasyDepentyDepententymydependentymocking,2)增強Flexibilybya

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

將Eclipse與SAP NetWeaver應用伺服器整合。

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境