最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • 排序和搜索

    正文概述 掘金(知无涯者)   2021-07-12   464

    js原生自带的排序和搜索

    排序和搜索

    冒泡排序

    排序和搜索

    Array.prototype.bubbleSort = function() {
      for(let i = 0; i < this.length - 1; i ++){
        // 完成一轮
        for(let j = 0; j < this.length - 1 - i; j ++){
          // console.log(this[j], this[j+1]);
          if(this[j] > this[j+1]) {
            const tmp = this[j];
            this[j] = this[j+1];
            this[j+1] = tmp;
          }
        }
      }
    };
    
    
    
    const arr = [5, 4, 3, 2, 1];
    arr.bubbleSort(); 
    console.log(arr);
    

    时间复杂度:O(n2)O(n^{2})O(n2)

    选择排序

    排序和搜索

    Array.prototype.selectSort = function() {
    
      // 一轮
      for(let i = 0; i < this.length - 1; i ++) {
        let indexMin = i;
        for(let j = i; j < this.length; j++){
          if(this[j] < this[indexMin]){
            indexMin = j;
          }
        }
        if(indexMin !== i){ 
          const tmp = this[i];
          this[i] = this[indexMin];
          this[indexMin] = tmp;
        }
      }
    }
    
    
    const arr = [5,4,3,2,1];
    arr.selectSort();
    console.log(arr);
    

    时间复杂度:O(n2):O(n^{2}):O(n2)

    归并排序

    排序和搜索

    Array.prototype.mergeSort = function(){
    
      // 递归 
      const rec = (arr) => {
        if(arr.length === 1) return arr;
        const mid = Math.floor(arr.length / 2);
        const left = arr.slice(0, mid);
        const right = arr.slice(mid, arr.length);
        const orderLeft =  rec(left);
        const orderRight = rec(right);
        // 合并
        const res = [];
        while(orderLeft.length || orderRight.length) {
          if(orderLeft.length && orderRight.length){
            res.push(orderLeft[0] < orderRight[0] ? orderLeft.shift() : orderRight.shift())
          }else if(orderLeft.length){
            res.push(orderLeft.shift())
          }else if(orderRight.length){
            res.push(orderRight.shift());
          }
        }
        return res;
      }
      const res =  rec(this);
      res.forEach((n, i) => {this[i] = n})
    }
    
    const arr = [5,4,3,2,1];
    arr.mergeSort();
    console.log(arr);
    

    时间复杂度:O(nlogn):O(nlog{n}):O(nlogn)

    快速排序

    排序和搜索

    Array.prototype.quickSort = function() {
      const rec = (arr) => {
        if(arr.length === 1) return arr;
        const left = [];
        const right = [];
        const mid = arr[0];
        for(let i = 1; i < arr.length; i ++) {
          if(arr[i] < mid){
            left.push(arr[i]);
          }else{
            right.push(arr[i])
          }
        }
        return [...rec(left), mid, ...rec(right)];
    
      };
    
      const res = rec(this);
      res.forEach((n, i) => {
        this[i] = n;
      })
    }
    
    
    const arr = [2,4,5,1,3]; 
    arr.quickSort();
    console.log(arr);
    

    顺序搜索

    排序和搜索

    Array.prototype.sequentialSearch = function(target) {
    
      for(let i = 0; i < this.length; i ++){
        if(this[i] === target){
          return i;
        }
      }
      return -1;
    }
    
    
    const arr = [1, 3, 5, 7, 9];
    const res = arr.sequentialSearch(5);
    console.log(res);
    

    时间复杂度:O(N):O(N):O(N)

    二分搜索

    排序和搜索

    Array.prototype.binarySearch = function(target) {
      let low = 0;
      let high = this.length - 1;
      while(low <= high){
        const mid = Math.floor((low + high) / 2);
        const element = this[mid];
        if(element < target){
          low = mid + 1;
        }else if(element > target){
          high = mid - 1;
        }else {
          return mid;
        }
      }
      return -1;
    }
    
    
    const arr = [1, 2, 3, 4, 5];
    
    const res = arr.binarySearch(3);
    console.log(res);
    

    时间复杂度:O(logN)O(logN)O(logN)

    LeetCode 21 合并两个有序链表

    /**
     * Definition for singly-linked list.
     * function ListNode(val, next) {
     *     this.val = (val===undefined ? 0 : val)
     *     this.next = (next===undefined ? null : next)
     * }
     */
    /**
     * @param {ListNode} l1
     * @param {ListNode} l2
     * @return {ListNode}
     */
    var mergeTwoLists = function(l1, l2) {
        const dummy = new ListNode(-1);
        let p = dummy;
        while(l1 && l2){
            if(l1.val < l2.val){
                p.next = l1;
                p = p.next;
                l1 = l1.next;
            }else{
                p.next = l2;
                p = p.next;
                l2 = l2.next;
            }
        }
    
        if(l1) p.next = l1;
        if(l2) p.next = l2;
        return dummy.next;
    };
    

    LeetCode 374 猜数字大小

    /** 
     * Forward declaration of guess API.
     * @param {number} num   your guess
     * @return 	            -1 if num is lower than the guess number
     *			             1 if num is higher than the guess number
     *                       otherwise return 0
     * var guess = function(num) {}
     */
    
    /**
     * @param {number} n
     * @return {number}
     */
    var guessNumber = function(n) {
    
        let l = 1;
        let r = n;
        while(l <= r){
            const mid = Math.floor((l + r) / 2);
            const res = guess(mid);
            if(res === 0){
                return mid;
            }else if(res === 1){
                l = mid + 1;
            }else if(res === -1){
                r = mid - 1;
            }
        };
    
    };
    

    起源地下载网 » 排序和搜索

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元