js编写快速排序
之前一直學的c語言版的數據結構,所以想嘗試一下js版的快速排序,發現更有趣。
其實原理都是大同小異的,下面就來介紹一下原理。
1、首先選一個“基準”,一般選中間值比較合適,因為選兩頭數據都有可能出現最壞的情況。
2、將數組中的數據與“基準”比較,小于“基準”則存放在另一個數組left(左子集)中,大于“基準”則存放在數組right(右子集)中。
3、利用遞歸函數,將left和right分別重復1和2,每個數組剩下一個元素為止。
?
舉個栗子:
12 93 60 9 34 46 78 2 30
12 9 2 30 34 93 60 46 78
2 12 9 30 34 46 93 60 78
2 9 12 30 34 46 60 93 78
2 9 12 30 34 46 60 78 93
下面是代碼:
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html;charset=utf-8">
<script>
?
function quicksort(arr){
if(arr.length<=1)//判斷數組長度,如果小于等于1直接返回輸出
return arr;
var pviotIndex=Math.floor(arr.length/2);//取中間元素下標
var pviot=arr.splice(pviotIndex,1)[0];//返回中間元素,并刪除原數組中間元素
var left=[];
var right=[];
for(var i=0;i<arr.length;i++){
if(arr[i]<pviot){
left.push(arr[i]);//在left末尾追加小于基準的元素
}else{
right.push(arr[i]);
}
}
return quicksort(left).concat([pviotIndex],quicksort(right));//遞歸檢索比較,并且用concat把左子集、基準和右子集連接起來。
}
?
</script>
</head>
<body>
</body>
</html>
?
轉載于:https://www.cnblogs.com/wuxn/p/4895356.html
總結
- 上一篇: 团队项目-北航MOOC系统Android
- 下一篇: 最快最简单的排序(之二)——桶排序(简化