> 웹 프론트엔드 > JS 튜토리얼 > Javascript로 구현되는 일반적인 알고리즘(예: 버블, 고속, 비둘기집, 홀수-짝수 등)_javascript 기술

Javascript로 구현되는 일반적인 알고리즘(예: 버블, 고속, 비둘기집, 홀수-짝수 등)_javascript 기술

WBOY
풀어 주다: 2016-05-16 16:50:52
원래의
955명이 탐색했습니다.
코드 복사 코드는 다음과 같습니다.

l = [6, 2, 4, 1, 98, 34, 5, 9, 23, 8, 10, 32]

       
//冒泡排序
/*function bubbleSort(arr) {
    newarr = arr.slice()
    if (newarr.length <= 2) return newarr
    for (var i = 0; i < newarr.length - 1; i ) {
        for (var j = 0; j < newarr.length - i - 1; j ) {
            if (newarr[j] > newarr[j 1]) {
newarr[j] = [newarr[j 1], newarr[j 1] = newarr[j]][0]

            }
        }
    }
    newarr 반환
}

console.log(l)
result = bubbleSort(l)
console.log(result)*/

       
//快速排序
/* function QuickSort(arr) {
    if (arr.length <= 1) return arr;
    var left = [],
        right = [],
        middle = [];
var mid = arr[Math.floor(arr.length / 2)]
    for (var i = 0; i < arr.length; i ) {
        if (arr[i] < mid) {
            left.push(arr[i]);
        } else if (arr[i] > mid) {
            right.push(arr[i]);
        } else {
> var 결과 = QuickSort(l)
console.log(결과)

       
*/

//选择排序
/*function selectSort(arr) {
    var min = 9999,
        minindex = 0;
    var left = [],
        right = arr.slice();
    if (arr.length <= 1) return arr;
    for (var i = 0; 나는 < 도착 길이; i ) {
        if (arr[i] <= min) {
             min = arr[i];
            minindex = i;
        }
    }
    left.push( 분);   
    right.splice(minindex, 1);
    return [].concat(left, selectSort(right))
}

       
var 결과 = selectSort(l)
console.log(결과)*/

       
//插入排序
/*function insertSort(arr) {
    var tmp;
    for (var i = 1; i < arr.length; i ) {
        tmp = arr[i];
        for (var j = i; j > 0; j--) {
           if (arr[j - 1] > tmp) {
               arr[j] = arr[j - 1];
           } else {
              break;
            }
       }
        arr[j] = tmp;
    }
    return arr;
}

var results = insertSort(l)
console.log(results)*/

//木桶排序
/*function bucketSort(arr){
    var bucket = [];
    var newarr = [];
    for (var i = 0; i < arr.length; i ) {
버킷[arr[i]] = arr[i];
    }
    for (var i = 0; i < bucket.length; i ) {
        if (bucket[i] !== 정의되지 않음){
            newarr.push(bucket[i])
}
    }
    return newarr;
}

var results = bucketSort(l)
console.log(results)*/

//鸽巢排序,비负整数
/*function pigeonholeSort(arr){
    var tempArr = [];
    for(var i=0,l=arr.length;i tempArr[arr[i]] = (tempArr[arr[i]] 1)||1 ;
    }

    var result = [],count;
    for(var k=0; k        count = tempArr[k];
        if(count){
           for(var i=0;i                result.push (k);
            }
        }     
    }

    결과 반환;   
}

var 결과 = pigeonholeSort(l)
console.log(results)*/

//归并排序
/*function mergeSort(arr) {
    if (arr.length <= 1) return arr;
    var mid = Math.floor(arr.length / 2);
    var left = MergeSort(arr.slice(0, mid));
    var right = MergeSort(arr.slice(mid));
    var result = [];

    while (left.length && right.length) {
        if (왼쪽[왼쪽 .length - 1] <= right[0]) {
            result = result.concat(left);
            left = [];
        } else if (right[right.length - 1] < ; 왼쪽[0]) {
            result = result.concat(right);
            right = [];
        } else {
           if (right[0] < left[0]) {
               result.push(right.shift());
           } else {
              result.push(left.shift());
            }
       }
    }
    결과 = result.concat(왼쪽, 오른쪽);

    결과 반환;
}*/

       

/*function mergeSort(arr) {
    var merge = 함수(왼쪽, 오른쪽) {
        var result = [];
        while (left.length > 0 && 오른쪽.길이 > 0) {
            if (left[0] < right[0]) {
               result.push(left.shift());
            } else {
               result.push(right. 교대 ());
            }
        }
        return result.concat(left).concat(right);
    }

    if (arr.length == 1) return arr;
    var middle = Math.floor(arr.length / 2),
        left = arr.slice(0, middle),
        right = arr.slice(middle);
    return merge(mergeSort (왼쪽), mergeSort(오른쪽));
}

var 결과 = mergeSort(l)
console.log(결과)

*/

       
//堆排序

/ *function heapSort(arr) {
    var findRoot = function(arr, p, length) {
        p = p || 0;
        길이 = 길이 || arr.length;
        var self = 인수.callee;
        var l = p * 2 1;
        var r = (p 1) * 2;
        var 왼쪽, 오른쪽;

        if (l < length) left = self(arr, l, length);
        if (r < length) right = self(arr, r, length);
        if (left > arr [p]) arr[p] = [왼쪽, arr[l] = arr[p]][0];
        if (right > arr[p]) arr[p] = [right, arr[r ] = arr[p]][0];

        return arr[p];
    };

       
    for (var i = arr.length; i > 0 ; i--) {
        findRoot(arr, 0, i);
        arr[i - 1] = [arr[0], arr[0] = arr[i - 1]][0];
    }
    return arr;
}

var results = heapSort(l)
console.log(results)*/

       

//奇偶排列

/*functionoddEvenSort(arr) {
    var swaped = true,
        k = 0;
    while(swaped) {
        if (k > 0 ) swaped = false;

        for (var i = k; i < arr.length - 1; i = 2) {
            if (arr[i]>arr[i 1]) {
               arr[i] = [ arr[i 1], arr[i 1]=arr[i] ][0];
               swaped = true;
           }
        }
        k = [1, 0][k]
    }
    return arr;
}

var results =oddEvenSort(l)
console.log(results)*/

functionoddEvenSort(arr) {
    var swaped = true;
    while (swaped) {
        swaped = false;
        for (var i = 0; 나는 < 도착 길이; i = 2) {
           if (arr[i] > arr[i 1]) {
               arr[i] = [arr[i 1], arr[i 1] = arr[i]][ 0];
                교환 = true;
           도착[i] > ; arr[i 1]) {
                arr[i] = [arr[i 1], arr[i 1] = arr[i]][0];
               swaped = true;
            }
        }
    }
    return arr;
}

var results =oddEvenSort(l)
console.log(results)

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿