码迷,mamicode.com
首页 > 编程语言 > 详细

7、数组去重和排序

时间:2017-08-03 20:12:49      阅读:170      评论:0      收藏:0      [点我收藏+]

标签:记录   style   blog   循环   ret   cti   判断   i++   中间   

一、数组去重

    /**
     * 数组去重
     * 1、双循环法-判断有无相等项
     * 注意:第二个循环要从 i+1 开始
     * */
    let circleRepeat = function (ary) {
        for(let i=0;i<ary.length;i++){
            let cur = ary[i];
            for(let j=i+1;j<ary.length;j++){
                if(cur === ary[j]){
                    ary.splice(j,1);
                    j--;
                }
            }
        }
        return ary
    };
//    console.log(circleRepeat([1,2,3,4,1,1,2,2,3,4,4]));
    /**
     * 数组去重
     * 2、新数组法-新数组没有当前项-放入新数组
     * 注意:indexOf 用法
     * */
    let newArrRepeat = function (ary) {
        let ary2 = [];
        for(let i=0;i<ary.length;i++){
            let cur = ary[i];
            if(ary2.indexOf(cur) === -1){
                ary2.push(cur);
            }
        }
        return ary2
    };
//    console.log(newArrRepeat([1,2,3,4,1,1,2,2,3,4,4]));
    /**
     * 数组去重
     * 3、sort排序法-排序后判断相邻两项是否相等
     * 注意:sort用法和防止数组塌陷
     * */
    let sortRepeat = function (ary) {
        ary.sort(function (a,b) {
            return a-b;
        });
        for(let i=0;i<ary.length;i++){
            if(ary[i] === ary[i+1]){
                ary.splice(i,1);
                i--;//预防数组塌陷
            }
        }
        return ary;
    };
//    console.log(sortRepeat([1,2,3,4,1,1,2,2,3,4,4]));
    /**
     * 数组去重
     * 4、对象法-看对象中是否有重复的,如果有,删除数组该项
     * 注意:对象的属性名与属性值
     * */
    let objRepeat = function (ary) {
        let obj={};
        for(let i=0; i<ary.length; i++){
            let cur=ary[i];
            if(obj[cur]==cur){
                ary.splice(i,1);
                i--;
            }
            obj[cur]=cur;
        }
        return ary;
    };
//    console.log(objRepeat([1,2,3,4,1,1,2,2,3,4,4]));
    /**
     * 数组去重
     * 5、对象不重名特性-利用对象不重名的特性 不仅可以去重-属性名;而且属性值还记录了当前元素出现的次数
     * 注意:对象的属性名与属性值
     * */
    let objNameRepeat = function (ary) {
        let obj={},ary2=[];
        for(let i=0; i<ary.length; i++){
            let cur=ary[i];
            /*if(obj[cur]){
             obj[cur]++;
             continue;
             }
             obj[cur]=1; //给对象添加数组中的该项内容,并赋值为1;*/
            if(obj[cur]){
                obj[cur]++;
            }else{
                obj[cur]=1;
            }
        }

        return obj;
    };
//    console.log(objNameRepeat([1,2,3,4,1,1,2,2,3,4,4]));

二、数组排序

    /**
     * 快速排序
     * 1、找中间位置及对应的值
     * 2、数组中的每一项与中间值比较 left[]  right[]
     * 3、递归+数组拼接
     * */
    let quickSort = function (ary) {
        if(ary.length<=1){
            return ary
        }
        let num = Math.floor(ary.length/2);
        let numValue = ary.splice(num,1)[0];
        let left = [],right = [];
        for(let i=0;i<ary.length;i++){
            let cur = ary[i];
            if(cur<numValue){
                left.push(cur)
            }else {
                right.push(cur)
            }
        }
        return quickSort(left).concat([numValue],quickSort(right))
    };
//    console.log(quickSort([2,43,7,89,0,6,4,2,5,6]))

    /**
     * 插入排序
     * 1、取数组第一项对应的值作比较。
     * 2、循环原数组与left数组
     * 3、原数组当前项小于left中每一项,放到left最前面。
     * 4、原数组当前项大于left中其中某一项,放到此项后面。
     * 5、返回left
     * */
    let insertSort = function (ary) {
        let left = ary.splice(0,1);
        for(let i=0;i<ary.length;i++){
            let cur = ary[i];
            for(let j=left.length-1;j>=0;){
                if(cur<left[j]){
                    j--;
                    if(j == -1){
                        left.unshift(cur);
                    }
                }else {
                    left.splice(j+1,0,cur);
                    break;
                }
            }
        }
        return left
    };
//    console.log(insertSort([2,43,7,89,0,6,4,2,5,6]))
    /**
     * 冒泡排序
     * 1、第一个循环--> 数组的长度=比较的轮数 ary.length
     * 2、第二个循环--> 每轮比较的次数 ary.length-1-i(最后一项不用比较)
     * 3、每次比较把较大值放到后面-->每轮比较最大值放到了最后
     * 4、返回数组
     * */
    let bubbleSort = function (ary) {
        for(let i=0;i<ary.length;i++){
            for(let j=0;j<ary.length-1-i;j++){
                if(ary[j]>ary[j+1]){
                    let tmp = ary[j+1];
                    ary[j+1] = ary[j];
                    ary[j] = tmp;
                }
            }
        }
        return ary
    };
//    console.log(bubbleSort([2,43,7,89,0,6,4,2,5,6]));

 

7、数组去重和排序

标签:记录   style   blog   循环   ret   cti   判断   i++   中间   

原文地址:http://www.cnblogs.com/dalyn/p/7281267.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!