详解js中常用4个基础算法

 更新时间:2023年05月25日 12:09:51   作者:逆风起飞  
本文主要介绍了JS中常用的四个基础算法,主要介绍了冒泡排序,选择排序,插入排序和快速排序这四种算法,需要的朋友可以参考下

冒泡排序

原理

相邻两个数据的按条件交换排序,然后遍历式的交换排序。
何为冒泡?每次遍历为一次 冒泡,一次遍历完成,冒泡结束至少会让一个元素移动到正确的位置。
列:

const arr = [3, 2, 1];
// 第1次冒泡后[2, 1,3] 3移动到正确位置
// 第2次冒泡后[1,2,3] 2移动到正确位置

它排序需要两次循环来设计:
第一层循环控制排序arr.length - 1
第二层循环负责每次交换遍历数据的相邻数据交换, 共arr.length - 1 - i次,i第一层循环 已循环次数。

代码

export const mySort = arr => {
  for (let i = 0; i < arr.length - 1; i++) {
    // 控制循环次数
    for (let j = 0; j < arr.length - i - 1; j++) {
      // 数据交换
      if (arr[j] > arr[j + 1]) {
        const temp = arr[j];
        arr[j] = arr[j + 1];
        arr[j + 1] = temp;
      }
    }
  }
  return arr;
};

实现array.sort:

export const mySort = (arr, fn) => {
  for (let i = 0; i < arr.length - 1; i++) {
    // 控制循环次数
    for (let j = 0; j < arr.length - i - 1; j++) {
      // 数据交换
      if (fn(arr[j], arr[j + 1])) {
        const temp = arr[j];
        arr[j] = arr[j + 1];
        arr[j + 1] = temp;
      }
    }
  }
  return arr;
};
mySort([1, 5, 3, 8, 2, 4], (a, b) => a > b); //  [1, 2, 3, 4, 5, 8]
mySort([1, 5, 3, 8, 2, 4], (a, b) => a < b); // [8, 5, 4, 3, 2, 1]

选择排序

原理

对数组遍历后选取符合条件(最大或最小)的数,与数组对应位置的数进行交换。
何为选择?每次遍历为一次 选择,一次遍历完成结束会得出一个符合条件的元素并交换位置。
列:

const arr = [3, 2, 1];
// 第1次选择后[1, 2,3] 1与3交换位置
// 第2次选择后[1, 2,3] 

它与冒泡排序不同的是它不会频繁的发生交换,第一层循环结束后,看条件是否满足需要交换。
它排序需要两次循环来设计:
第一层循环控制排序arr.length - 1
第二层循环负责找出交换下标indexj = ij前面已排好。

代码

export const mySort = (arr, fn) => {
  for (let i = 0; i < arr.length - 1; i++) {
    // 控制循环次数
    let index = i;
    for (let j = i; j < arr.length; j++) {
      // 找出下标
      if (fn(arr[j], arr[index])) {
        index = j;
      }
    }
    // 交换数据
    if (index !== i) {
      const copy = arr[index];
      arr[index] = arr[i];
      arr[i] = copy;
    }
  }
  return arr;
};
mySort([9, 5, 3, 4], (a, b) => a > b); // [9, 5, 4, 3]

插入排序

原理

以下内容来自参考文章:@插入排序通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。
一般来说,插入排序都采用 in-place 在数组上实现:

  • 从第一个元素开始,该元素可以认为已经被排序;
  • 取出下一个元素,在已经排序的元素序列中从后向前扫描;
  • 如果该元素(已排序)大于新元素,将该元素移到下一位置;
  • 重复步骤3,直到找到已排序的元素小于或者等于新元素的位置;
  • 将新元素插入到该位置后;
  • 重复步骤2~5。

动图展示

代码

const insertion = arr => {
  const len = arr.length;
  let preIndex;
  let current;
  for (let i = 1; i < len; i++) {
    preIndex = i - 1;
    current = arr[i];
    while (preIndex >= 0 && current < arr[preIndex]) {
      arr[preIndex + 1] = arr[preIndex];
      preIndex--;
    }
    arr[preIndex + 1] = current;
  }
  return arr;
};
insertion([3, 5, 7, 1, 4, 56, 12, 78, 25, 0, 9, 8, 42, 37]);
//  [0, 1, 3, 4, 5, 7, 8, 9, 12, 25, 37, 42, 56, 78]

快速排序

原理

快速排序使用分治法策略来把一个数组分为两个数组,再重复把这两个数组变成四个,直至length <= 1。 思路:

  • 从数组中挑出一个元素,称为 "基准"。
  • 重新排序数组,所有元素比基准值小的摆放在基准前面(left),所有元素比基准值大的摆在基准的后面(right),相同的数可以到任一边。在这个分区退出之后,该基准就处于数列的中间位置。这个称为分区操作。
  • 递归 地把小于基准值元素的数组和大于基准值元素的数组排序,重复1~2。

代码

const quickSort = arr => {
  const len = arr.length;
  if (len <= 1) return arr;
  // 基准
  const num = arr[0];
  // 左右分区
  const left = [];
  const right = [];
  for (let index = 1; index < arr.length; index++) {
    arr[index] <= num ? left.push(arr[index]) : right.push(arr[index]);
  }
  // 递归
  return quickSort(left).concat([num], quickSort(right));
};
console.log(quickSort([3, 2, 6, 8, 99, 2, 3]));// [2, 2, 3, 3, 6, 8, 99]

以上就是详解js中常用4个基础算法的详细内容,更多关于js基础算法的资料请关注脚本之家其它相关文章!

相关文章

  • JavaScript实现循环轮播图

    JavaScript实现循环轮播图

    这篇文章主要为大家详细介绍了JavaScript实现循环轮播图,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-04-04
  • js从外部获取图片的实现方法

    js从外部获取图片的实现方法

    下面小编就为大家带来一篇js从外部获取图片的实现方法。小编觉得挺不错的, 现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-08-08
  • JS sort排序详细使用方法示例解析

    JS sort排序详细使用方法示例解析

    这篇文章主要介绍了JS sort排序详细使用方法示例解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-09-09
  • ionic 自定义弹框效果

    ionic 自定义弹框效果

    这篇文章主要介绍了ionic 自定义弹框效果,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2017-06-06
  • Bootstrap table使用方法总结

    Bootstrap table使用方法总结

    这篇文章主要总结介绍了Bootstrap table的使用方法,服务器分页、客户端分页的转换,table刷新,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-05-05
  • javascript 得到文件后缀名的思路及实现

    javascript 得到文件后缀名的思路及实现

    在上传文件时,常常要对文件的类型即对文件的后缀名进行判断,用javascript可以很容易的做到这一点。用Javascript解析一个带绝对路径的文件名并得到后缀名的方法有很多种,这里列出一种,以供参考。
    2013-07-07
  • JavaScript实现时间格式的切割与转换

    JavaScript实现时间格式的切割与转换

    这篇文章主要为大家详细介绍了使用JavaScript实现时间格式的切割与转换的相关知识,文中的示例代码讲解详细,有需要的小伙伴可以参考一下
    2024-04-04
  • 详解CocosCreator游戏之鱼群算法

    详解CocosCreator游戏之鱼群算法

    这篇文章主要介绍了详解CocosCreator游戏之鱼群算法,对算法感兴趣的同学,可以仔细参考下
    2021-04-04
  • Chrome插件(扩展)开发全攻略(完整demo)

    Chrome插件(扩展)开发全攻略(完整demo)

    Chrome插件是一个用Web技术开发、用来增强浏览器功能的软件,它其实就是一个由HTML、CSS、JS、图片等资源组成的一个.crx后缀的压缩包,本文给大家分享一个Chrome插件(扩展)开发全攻略完整demo,感兴趣的朋友跟随小编一起学习下吧
    2021-05-05
  • javascript 手动给表增加数据的小例子

    javascript 手动给表增加数据的小例子

    这篇文章介绍了js手动给表增加数据的实例代码,有需要的朋友可以参考一下
    2013-07-07

最新评论