// 插入排序
function insertionSort(ary){
let newAry= [];
newAry.push(ary[0]);
for(let i=1;i<ary.length;i++){
let A = ary[i]; // A 新拿到的
// 和手里的數(shù)組相比較(從后向前比較)
for(let j=newAry.length-1;j>=0;j--){
let B = newAry[j];
if (A > B){
newAry.splice(j+1,0,A);
break;
}
if(j === 0){ //已經(jīng)比到了第一項(xiàng) 我們把新數(shù)據(jù)直接插到第一項(xiàng)
newAry.unshift(A)
}
}
};
return newAry;
}
// 快速排序
function quickSort(ary){
if(ary.length<=1){
return ary;
}
// 找到數(shù)組的中間項(xiàng) 在原有的數(shù)組中把它移除
let middleIndex = Math.floor(ary.length / 2);
let middleValue = ary.splice(middleIndex,1)[0];
// 準(zhǔn)備左右兩個(gè)數(shù)組
let left = [];
let right = [];
for(let i = 0; i < arr.length; i++){
let cur = arr[i];
if(cur < middleValue){
left.push(cur);
}else{
right.push(cur)
}
}
return quickSort(left).concat(middleValue,quickSort(right))
}