【PHP面試題】通俗易懂的兩個面試必問的排序算法講解:冒泡排序和快速排序

又到了金三銀四找工做的時間,相信不少開發者都在找工做或者準備着找工做了。通常應對面試,咱們無可厚非的去刷下面試題。對於PHPer來講,除了要熟悉本身所作的項目,還有懂的基本的算法。下面來分享下PHP面試中常會問到的算法:冒泡排序和快速排序php

 

冒泡排序:一一對比排序面試

基本思想:

重複地走訪過要排序的元素列,依次比較兩個相鄰的元素,若是他們的順序(如從大到小)錯誤就把他們交換過來。走訪元素的工做是重複地進行直到沒有相鄰元素須要交換,也就是說該元素已經排序完成。算法

 

圖解:

 

1.第一次:拿着數組的第一個元素,分別從第二個元素開始比較,若是前面的元素比後面的元素大,則交換兩個元素,獲得較大的這個值,繼續向後比較,直到數組元素的最後,實現一次冒泡(冒泡一次,就獲得當前「剩餘」數組的最大值,而且放到數組的「最後面」)數組

2.第二次開始,仍是從第一個元素開始比較,可是隻比較到數組長度要-1位置,而且每次的比較次數都依次-1函數

3.後面重複比較,直到最後沒有須要一堆數字須要比較學習

代碼:

 1         $arr = array(3,2,6,0,1,4,7);
 2         //由於排序須要每次將一個元素與數組的其餘元素進行比較,因此須要兩層循環來控制
 3         //外層循環控制冒泡次數
 4         //內存循環比較每次的大小,獲得每次的最大值(泡)
 5  
 6         for($i = 0,$length = count($arr);$i < $length;$i++){
 7         
 8                  //內存循環
 9                  for($j = 0;$j < ($length - $i - 1);$j++){
10                          //拿着j變量所對應的數組元素,與後面的元素進行比較
11                          if($arr[$j] > $arr[$j + 1]){
12                                   //交換位置
13                                   $temp              = $arr[$j];
14                                   $arr[$j]           = $arr[$j+1];
15                                   $arr[$j+1]         = $temp;
16                          }
17                  }
18         }

總結:

冒泡排序最好的時間複雜度是O(n),雖說它不是最優的算法,可是這是咱們常常接觸到的,面試也會給問到,因此咱們必定要懂的基本原理,能理解到,能寫的出來ui

 

快速排序:用空間換時間spa

基本思想:

經過一趟排序將要排序的數據分割成獨立的兩部分,其中一部分的全部數據都比另一部分的全部數據都要小,而後再按此方法對這兩部分數據分別進行快速排序,整個排序過程能夠遞歸進行,以此達到整個數據變成有序序列。code

圖解:

 

 

找到當前數組中的任意一個元素,做爲標準,新建兩個空數組,遍歷整個數組元素,遍歷到的元素比當前元素要小,那麼放到左邊的數組;若是要大,放到另一個數組中對象

遞歸思路

1.遞歸點:若是兩個數組的元素大於1,就須要再進行分解

2.遞歸出口:數組元素變成1的時候

代碼:

        
 1 //待排序數組
 2         $arr = array(5,3,8,2,6,4,7);
 3         //函數實現快速排序
 4         function quick_sort($arr){
 5                  //判斷參數是不是一個數組
 6                  if(!is_array($arr)) return false;
 7  
 8                  //遞歸出口:數組長度爲1就直接返回數組
 9                  $length = count($arr);
10                  if($length <= 1) return $arr;
11 
12                  //數組元素有多個
13                  $left = $right = array();
14                  //使用for循環進行遍歷,把第一個元素當作比較的對象
15                  for($i = 1;$i < $length;$i++){
16                          //判斷當前元素值的大小
17                          if($arr[$i] < $arr[0]){
18                                   //當前元素小於標準元素,放到左邊數組
19                                   $left[] = $arr[$i];
20                          }else{
21                                   $right[] = $arr[$i];
22                          }
23                  }
24                  //遞歸調用
25                  $left = quick_sort($left);
26                  $right = quick_sort($right);
27  
28                  //將全部的結果合併
29                  return array_merge($left,array($arr[0]),$right);
30         }

總結:

快速排序在通常的排序的方式中最快的排序方式,以遞歸爲基礎,使用空間換時間。在通常的面試中會給問到,要能知道基礎原理。

 

------------------------------------------------------------------------------

歡迎關注個人公衆號【phper的進階之路】,將不斷更新各類技術心得,免費提供各類學習資源!!!
相關文章
相關標籤/搜索