Js中的排序

關(guān)于算法的問題

冒泡排序

第一次循環(huán),從第一位開始,與后一位的進行比較,如果前一位比后一位大則交換兩個的值,一直比對到最后一位,這樣最后一個值就是最大的值了,下一次循環(huán)就沒有必要和最后一項比了,所以每次循環(huán)都要減少一次對比

  • 代碼如下
function bubbleSort(arr) {
        var change = function (index1, index2) {
            var temp = arr[index1]
            arr[index1] = arr[index2]
            arr[index2] = temp
        }
        var len = arr.length
        if (len <= 1)  return arr
        for (var i = 0; i < len - 1; i++) { // 表示有l(wèi)en-2輪外循環(huán)
            for (var j = 0; j < len - 1 - i; j++) { // 每完成一輪則減少一次內(nèi)循環(huán),因為最后一個的位置是排好的
                if (arr[j] > arr[j + 1]) {
                    change(j, j + 1)
                }
            }
        }
        return arr
    }

選擇排序

第一次循環(huán),找出最小的值排序到第一位上,這樣下一次循環(huán)的時候就不用從第一位開始比較了,因為他已經(jīng)是里面最小的了,下一次循環(huán)也就是找最小的值然后排在第二位上,以此來進行排序

  • 代碼如下
 function chooseSort(arr) {
        var len = arr.length
        if (len <= 1) return arr
        var max = 0
        for (var i = 0; i < len; i++) {
            max = i
            for (var j = i; j < len; j++) { // 內(nèi)循環(huán)然后找出最小的index然后與i位置上的值進行交換
                if (arr[j] > arr[max]) {
                    max = j
                }
            }
            if (max != i) {
                var change = arr[i]
                arr[i] = arr[max]
                arr[max] = change
            }
        }
        return arr
    }

插入排序

每次循環(huán)獲取固定的插入項,插入項和其前面的值進行比較,插入比他小的值的后面,若比較的過程中比插入值大,則比較項向后挪空出位置給插入項,依次比較后插入插入值即可

  • 代碼如下
 function insertSort(arr) {
        var len = arr.length,j,insert
        if (len < 0) return 0
        for (var i = 1; i < len; i++) {
            j = i
            insert = arr[i] // 獲取插入值
            while (insert < arr[j - 1] && j > 0) { // 比較插入值和前面的值進行比較
                arr[j] = arr[j-1]
                j--
            }
            arr[j] = insert
        }
        return arr
    }

選擇排序

第一次循環(huán),找出最小的值排序到第一位上,這樣下一次循環(huán)的時候就不用從第一位開始比較了,因為他已經(jīng)是里面最小的了,下一次循環(huán)也就是找最小的值然后排在第二位上,以此來進行排序

  • 代碼如下
 function chooseSort(arr) {
        var len = arr.length
        if (len <= 1) return arr
        var max = 0
        for (var i = 0; i < len; i++) {
            max = i
            for (var j = i; j < len; j++) { // 內(nèi)循環(huán)然后找出最小的index然后與i位置上的值進行交換
                if (arr[j] > arr[max]) {
                    max = j
                }
            }
            if (max != i) {
                var change = arr[i]
                arr[i] = arr[max]
                arr[max] = change
            }
        }
        return arr
    }

歸并排序

要進行歸并首先要分離,將一個一個的大數(shù)組,從“中”分開,一直分裂到全是只有一個元素的數(shù)組,然后依次比較后合并。

  • 代碼如下
// 歸并利用了遞歸,將無序的數(shù)組進行分割,成一個一個的小數(shù)組,重新歸并成一個排好序的大數(shù)組
    function mergeSort(arr) {
        var len = arr.length
        if (len === 1) return arr
        var mid = ~~(len / 2),
                left = arr.slice(0, mid),
                right = arr.slice(mid)
        console.log(left,right,'分組')
        return merge(mergeSort(left),mergeSort(right))
    }
    function merge(left, right) {
        console.log(left,right,'合并')
        var result = []
        while(left.length && right.length) { // 一個一個值進行抽離對比,小的放進去,首先兩邊的數(shù)組排好序
            if(left[0] <right[0]) {
                result.push(left.shift())  //數(shù)組不斷的從新抽離分配
            } else {
                result.push(right.shift())
            }
        }
        result = result.concat(left,right)
        console.log(result,'結(jié)果')
        return result
    }
    var arr1 = [2,4,1,5,3,6]
    mergeSort(arr1)
    // 分組順序 左left 右right
    // [2, 4, 1] [5, 3, 6]
    // [2] [4, 1]
    // [4] [1]
    // [5] [3, 6]
    // [3] [6]

    // [2, 4, 1] [5, 3, 6] "分組"
    // [2] [4, 1] "分組"
    // [4] [1] "分組"
    // [4] [1] "合并"  4>1 => [1] => [1,4]
    // [2] [1, 4] "合并" 2>1 => [1] => 2<4 => [1,2] => [1,2,4]
    // [5] [3, 6] "分組"
    // [3] [6] "分組"
    // [3] [6] "合并" 3<6 => [3,6]
    // [5] [3, 6] "合并" 5<3 => [3] => 5<6 => [3,5] => [3,5,6]
    // [1, 2, 4] [3, 5, 6] "合并" 1<3 => [1] => 2<3 => [1,2] => 4>3 => [1,2,3] => 4<5 => [1,2,3,4] => [1,2,3,4,5,6]
    // [1, 2, 3, 4, 5, 6]

快速排序

設(shè)置一個基準,大于基準在右邊,小于基準在左邊,然后在不斷的去分化分好的數(shù)組,直到只剩下一個元素的數(shù)組

  • 代碼如下
// 使用遞歸
function quickSort(arr) {
        var len = arr.length
        var left = []
        var right = []
        if (len <= 1) return arr
        var mid = ~~(len / 2)
        for (var i = 0; i < len; i++) {
            if (i === mid) continue
            if (arr[i] < arr[mid]) {
                left.push(arr[i])
            } else {
                right.push(arr[i])
            }
        }
        return quickSort(left).concat(arr[mid],quickSort(right))
    }
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 排序的基本概念 在計算機程序開發(fā)過程中,經(jīng)常需要一組數(shù)據(jù)元素(或記錄)按某個關(guān)鍵字進行排序,排序完成的序列可用于快...
    Jack921閱讀 1,576評論 1 4
  • 作者:大海里的太陽原文地址:http://www.cnblogs.com/wxisme/ 前言 查找和排序算法是算...
    IT程序獅閱讀 2,632評論 0 63
  • 前言 查找和排序算法是算法的入門知識,其經(jīng)典思想可以用于很多算法當中。因為其實現(xiàn)代碼較短,應(yīng)用較常見。所以在面試中...
    寶塔山上的貓閱讀 1,166評論 1 21
  • 月亮高懸 天空是一無所有的充實 背上行囊 遠方是行走的魔障 是誰在夜色裹挾中不斷地迷失 遮掩不住,內(nèi)心的彷徨 掛念...
    電影夫人閱讀 1,572評論 13 52
  • 兩只眼皮在打架,我的月亮去哪啦? 月亮你真不該呀,誰把思念寄予他? 沒能抓住佳節(jié)的尾巴,卻無法忘記他! 明明放不下...
    瞿靜閱讀 253評論 0 0

友情鏈接更多精彩內(nèi)容