offer大作战-JS实现排序算法

一年一度的秋招已经开始了(哦,不对,已经快进入尾声了)
看着别人手里已经有offer了,自己手里还空落落的,很是着急啊
着急也没有啊,提升自己的实力才是关键啊
我们知道现在前端的就业形势(哎…),各大公司对基础的考究越来越多
特别是计算机基础的知识,对于自学前端的同学们来说,在学习前端之余,又赶上找工作的时期逼近,实在是对想补习计算机基础的同学来说心有余而力不足
虽然都说前端不会接触到什么算法,但是为了大家(and me)能找到更好工作,有一些经常容易考察的算法还是应该学习一哈
所以接下来,我都将把最近学习的一些知识点分享记录下来,以便自己巩固和其他同学参考
本篇文章就是主要是介绍一些常备的排序算法

1.冒泡排序
冒泡排序的思想就是依次比较大小,然后在位置上进行大小的交换。
下面我们用算法来实现

function bubble(arr) {  
    for(var i = 0,len = arr.length; i < len - 1; i++) {
        for(var j=i+1; j//如果前一位大于后一位则需要交换位置
          if(arr[i]>arr[j]) {
                var temp = arr[i];
                arr[i] = arr[j];
                arr[j] = temp;
            }
        }
    }
    return arr;
}

这就是冒泡排序的实现过程,其实就是循环比较,然后进行位置上的交换,达到排序的目的

2.快速排序
快速排序也是非常经典的排序了
按我的理解,快速排序的思想就像是二分法一样,二分之一,四分之一,然后八分之一……,一直这么分下去,直到排序完毕
在用程序实现中,我们也是这样,找一个相对中间的值(参考值),然后分成两块,一块全是比中间值小的,一块是比中间值都大的,这样我们就完成了第一次排序
然后我们再递归调用第一次排序的函数,执行一样的操作,然后就……搞定了,那么我们用代码来实现一下

function quick(arr) {
    //如果数组长度为1,直接返回
    if(arr.length <= 1) {
        return arr;
    }

    //定义大数组,小数组,参考值
    var lessArr = [];
    var moreArr = [];
    var consult = arr[0];
    for(let i = 1,len = arr.length; i < len; i++) {
        if(arr[i]>consult) {
            moreArr.push(arr[i]);
        }else{
            lessArr.push(arr[i]);
        }
    }

    //递归调用,最后返回排序后的数组
    return [].concat(quick(leftArr)[q],quickSort(rightArr));
}

3.选择排序
我感觉和冒泡排序相似,区别在于冒泡排序是没查询两个位置就进行交换,而选择排序是知道找到比当前位置小的数时才进行交换

function select(arr) {
    var minIndex, 
        temp;
    for(var i = 0, len = arr.length; i < len-1; i++) {
        minIndex = i;
        for(var j = i + 1; j < len; j++) {
            if (arr[j] < arr[minIndex]) {   
                minIndex = j;                
            }
        }
        temp = arr[i];
        arr[i] = arr[minIndex];
        arr[minIndex] = temp;
    }
    return arr;
}

4.插入排序
插入排序就是当前值的前一个值存在的前提下不断的与之比较,小则交换位置,大则结束

function insertion(arr) {
    var pre, 
        cur;
    for (var i = 1, len = arr.length; i < len; i++) {
        pre = i - 1;
        cur = arr[i];
        while(pre >= 0 && arr[pre] > cur) {
            arr[pre + 1] = arr[pre];
            pre--;
        }
        arr[pre + 1] = cur;
    }
    return arr;
}

这是目前考察比较多的几种排序方法,当然排序方法不止这几种
先列出这几种便于自己复习,同时也将继续学习其他的排序思想

你可能感兴趣的:(基础,排序算法)