实现数组的sort方法

javascript的Array.sort方法可以传一个函数作为排序标准,今天晚上是坐在阳台上发呆陪老婆,有一句没一句的聊,无聊就实现个sort玩。

代码如下:

	Array.prototype.sort2 = function(callback){
        var self = this;
        for (var i = self.length-1; i >0; i--) {
            for (var j = 0; j < i; j++) {
                if (callback(self[j],self[j+1])) {
                    var t = self[j];
                    self[j]=self[j+1];
                    self[j+1] = t;
                };
            };

        };
        return self;
    }
    var a = [];
    for (var i = 0; i < 10000; i++) {
       a.push(Math.random());
    };
    var dt = new Date();
    a.sort2(function(v1,v2){return v1>v2;});
    console.info((new Date())-dt);

  然后在下面的测试过程中,我交替运行sort2和sort,发现根本不是一个数量级的,大量数据的排序冒泡肯定不可行,改天再试试插排,看能不能缩短与内置的sort之间的差距。就怕这个sort是完全用js的解释语言写的,不是javascript写成的,那怎么也不能写成一样了……

时间: 2024-08-14 23:47:47

实现数组的sort方法的相关文章

数组的sort方法

今天在看<JavaScript高级程序设计第三版>时,学到了数组的sort方法.知道这个方法,但是一直没仔细研究过,这次发现,它是把数组内的值用toSting()变为字符串再进行比较,这样的话,无法保证排出来的顺序的正确性,比如 var values = [0, 1, 5, 10, 15]; values.sort(); alert(values); //0,1,10,15,5 因为数值 5 虽然小于 10, 但在进行字符串比较时, "10" 则位于 "5&quo

js 数组中sort方法存在的问题

chrome中测试sort方法 发现排序失效,查过资料发现,js数组的sort方法总会以第一个字符的ASCII值来进行比较排序 解决办法一:给sort方法指定一个比较函数作为参数,如下图 解决办法二:自己一个排序算法,自己造轮子 原文地址:https://www.cnblogs.com/xingguozhiming/p/8996700.html

JavaScript中数组Array.sort()排序方法详解

JavaScript中数组的sort()方法主要用于对数组的元素进行排序.其中,sort()方法有一个可选参数.但是,此参数必须是函数. 数组在调用sort()方法时,如果没有传参将按字母顺序(字符编码顺序)对数组中的元素进行排序,如果想按照其他标准进行排序,就需要进行传一个参数且为函数,该函数要比较两个值,并且会返回一个用于说明这两个值的相对顺序的数字. 1.对数字数组进行由小到大的顺序进行排序. 代码: var arr = [22,12,3,43,56,47,4]; arr.sort();

对数组的操作Array.prototype.sort 方法--alert( [1, 3, 9, 2].sort() )

1.   数组的 sort 方法 远远没有被充分利用,而且可能比开发者们想像的更加强大.很多开发者可能觉得 sort 方法可以用来做这种事情: [1, 3, 9, 2].sort(); // 返回 [1, 2, 3, 9] alert( [1, 3, 9, 2].sort() ) ……这没错,但它还有更强大的用法,比如这样: [ { name: "Robin Van PurseStrings", age: 30 }, { name: "Theo Walcott",

数组Array.sort()排序的方法

数组sort排序 sort比较次数,sort用法,sort常用 描述 方法sort()将在原数组上对数组元素进行排序,即排序时不创建新的数组副本.如果调用方法sort()时没有使用参数,将按字母顺序(更为精确地说,是按照字符编码的顺序)对数组中的元素进行排序.要实现这一点,首先应把数组的元素都转换成字符串(如果有必要的话),以便进行比较. 如果想按照别的顺序进行排序,就必须提供比较函数,该函数要比较两个值,然后返回一个用于说明这两个值的相对顺序的数字.比较函数应该具有两个参数a和b,其返回值如下

数组sort方法源码解析

我们提到数组排序都会想到数组的sort方法,这个方法用起来的确很方便,其原理还是用到了我们的冒泡排序,sort函数接受一个参数,参数为一个函数,如果不指定参数,则按照则按unicode码顺序排列. var arr=[7,3,6,1,5,12]; console.log(arr.sort());//[1, 12, 3, 5, 6, 7] console.log(arr.sort(function(a,b){ return a-b; })); //[1, 3, 5, 6, 7, 12] 其实源码实现

Array 的sort()方法详解

1.数组的sort()方法排序数字(按升序) 如果要排序数字49.5.9,那么sort()方法排序的结果是49.5.9.这是因为sort()方法默认情况下是进行升序排列.从左往右一位一位比较ASCII码大小,直至比较出大小   (若其中位数不足的补零) 那么我们应该如何利用sort()方法进行排序呢? 首先我们定义一个函数: /*升序*/ function sortNumbleUp(x,y){ return x-y; } /*降序*/ function sortNumbleDown(x,y){

5个数组去重的方法

1.遍历数组法 最简单的去重方法:新建一新数组,遍历传入数组,值不在新数组就加入该新数组中:注意点:判断值是否在数组的方法“indexOf”是ECMAScript5 方法,IE8以下不支持,需多写一些兼容低版本浏览器代码 function unique1(array){ var n = []; for(var i = 0; i < array.length; i++){ //如果当前数组的第i已经保存进了临时数组,那么跳过,否则把当前项push到临时数组里面 if (n.indexOf(arra

js数组排序 reverse()和sort()方法的使用

WEB前端|js数组排序reverse()和sort()方法的使用,数组中已经存在两个可以直接用来重排序的方法:reverse()和sort(). reverse()方法会对反转数组项的顺序. var values = [1, 2, 3, 4, 5]; values.reverse(); alert(values);  //5,4,3,2,1 这里数组的初始值及顺序是1.2.3.4.5.而调用数组的reverse()方法后,其值的顺序变成了5.4.3.2.1.这个方法的作用相当只管明了,但不够灵