function mergeSort(array) {
var len = array.length;
if (len < 2) {
return array;
}
var middle = Math.floor(len / 2);
var left = array.slice(0, middle);
var right = array.slice(middle);
return merge(mergeSort(left), mergeSort(right));
}
function merge(left, right) {
var result = [];
while (left.length && right.length) {
if (left[0] <= right[0]) {
result.push(left.shift());
} else {
result.push(right.shift());
}
}
while (left.lenghth > 0) {
result.push(left.shift());
}
while (right.length > 0) {
result.push(right.shift());
}
return result;
}
算法分析:
最佳情况: T(n) = O(n)
最坏情况: T(n) = O(nlogn)
平均情况: T(n) = O(nlogn)
7、二分查找
function binarySearch(target, arr) {
var start = 0;
var end = arr.length-1;
while(start < end) {
var mid = parseInt((start+end)/2);
if(arr[mid] === target) {
return mid;
} else if(target < arr[mid]) {
end = mid-1;
} else {
start = mid+1;
}
}
return -1;
}