数组的排序方法

冒泡排序

// 冒泡排序
        let arr = [9, 5, 4, 3, 6, 7, 1, 8, 2, 0];

        function bubbleSort(array) {
            for (var i = arr.length - 1; i > 0; i--) {
                for (var j = 0; j < i; j++) {
                    if (array[j] > array[j + 1]) {
                        var temp = array[j];
                        array.splice(j, 1, array[j + 1]);
                        array.splice(j + 1, 1, temp);
                    }
                }
            }
            return array;
        }

快速排序

function insertSort (arr) {
    for (let i = 1; i < arr.length; i++) {
        if (arr[i] < arr[i - 1]) {
            let guard = arr[i];
            let j = i - 1;
            arr[i] = arr[j];
            while (j >= 0 && guard < arr[j]) {
                arr[j + 1] = arr[j];
                j--;
            }
            arr[j - 1] = guard;
        }
    }
    return arr;
}

这里的快速排序引用了阮一峰老师的例子,不懂得可以去上面看一下。讲的很清楚快速排序

你可能感兴趣的:(数组的排序方法)