欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

javascript快速排序算法詳解

 更新時間:2014年09月17日 11:42:51   投稿:hebedich  
JavaScript實現(xiàn)的常見排序算法有:冒泡排序,選擇排序,插入排序,謝爾排序,快速排序(遞歸),快速排序(堆棧),歸并排序,堆排序。今天我們來詳細(xì)分析下快速排序算法

"快速排序"的思想很簡單,整個排序過程只需要三步:

 ?。?)在數(shù)據(jù)集之中,找一個基準(zhǔn)點

 ?。?)建立兩個數(shù)組,分別存儲左邊和右邊的數(shù)組

 ?。?)利用遞歸進行下次比較

看一個demo:http://jsdo.it/norahiko/oxIy/fullscreen(網(wǎng)頁打開可能較慢,慢慢等待吧)

<script type="text/javascript"> 

function quickSort(arr){
  if(arr.length<=1){
    return arr;//如果數(shù)組只有一個數(shù),就直接返回;
  }

  var num = Math.floor(arr.length/2);//找到中間數(shù)的索引值,如果是浮點數(shù),則向下取整
  var numValue = arr.splice(num,1);//找到中間數(shù)的值
  var left = [];
  var right = [];

  for(var i=0;i<arr.length;i++){
    if(arr[i]<numValue){
      left.push(arr[i]);//基準(zhǔn)點的左邊的數(shù)傳到左邊數(shù)組
    }
    else{
      right.push(arr[i]);//基準(zhǔn)點的右邊的數(shù)傳到右邊數(shù)組
    }
  }
 return quickSort(left).concat([numValue],quickSort(right));//遞歸不斷重復(fù)比較
}
alert(quickSort([32,45,37,16,2,87]));//彈出“2,16,32,37,45,87”

</script>

相關(guān)文章

最新評論