记录数组的冒泡排序、选择排序、插入排序、快速排序

//  冒泡排序: 让数组中的当前项和后一项进行比较,如果当前项比后一项大,则两项交换位置(让大的靠后)即可
function bubbleSort(arr){
    let temp = null;
    for(let i = 0; i < arr.length - 1; i++){   // 外层循环控制比较的轮数
        for(let j = 0; j < arr.length - 1 - i; j++){
            if(arr[j] > arr[j +1 ]){
                temp = arr[j];
                arr[j] = arr[j +1];
                arr[j +1] = temp;
            }
        }
    }
    return arr;
}
// 选择排序:两个for循环嵌套,外循环记录每次循环开始的位置,内循环查找本次循环内的最小值
function selectionSort(arr){
    let temp = null;
    for(let i = 0; i < arr.length; i++){
        for(let j = i+1; j < arr.length; j++){
            if(arr[i] > arr[j]){
                temp = arr[i];
                arr[i] = arr[j]
                arr[j] = temp;
            }
        }
    }
    return arr;
}
// 插入排序
function insertionSort(ary){
    let newAry= [];
    newAry.push(ary[0]);

    for(let i=1;i<ary.length;i++){
        let A = ary[i];   // A 新拿到的

        // 和手里的数组相比较(从后向前比较)
        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){  //已经比到了第一项 我们把新数据直接插到第一项
                newAry.unshift(A)
            }
        }
    };
    return newAry;
}
// 快速排序
function quickSort(ary){
    if(ary.length<=1){
        return ary;
    }

    // 找到数组的中间项  在原有的数组中把它移除
    let middleIndex = Math.floor(ary.length / 2);
    let middleValue = ary.splice(middleIndex,1)[0];

    // 准备左右两个数组
    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))
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

友情链接更多精彩内容