博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
js实现两种实用的排序算法——冒泡、快速排序
阅读量:4569 次
发布时间:2019-06-08

本文共 1195 字,大约阅读时间需要 3 分钟。

零:数据准备,给定数组arr=[2,5,4,1,7,3,8,6,9,0];

一:冒牌排序

1思想:冒泡排序思想:每一次对比相邻两个数据的大小,小的排在前面,如果前面的数据比后面的大就交换这两个数的位置

       要实现上述规则需要用到两层for循环,外层从第一个数到倒数第二个数,内层从外层的后面一个数到最后一个数

2特点:排序算法的基础。简单实用易于理解,缺点是比较次数多,效率较低。

3实现:

var times=0;var bubbleSort=function(arr){    for(var i=0;i
arr[j]){
//如果前面的数据比后面的大就交换 var temp=arr[i]; arr[i]=arr[j]; arr[j]=temp; } console.log("第"+(++times)+"次排序后:"+arr); } } return arr;}console.log("The result is:"+bubbleSort(arr));

 

4效率:数组长度10,排序次数45次。

 

二:快速排序

1思想:快速排序思想:先找到一个基准点(一般指数组的中部),然后数组被该基准点分为两部分,依次与该基准点数据比较,如果比它小,放左边;反之,放右边。

      左右分别用一个空数组去存储比较后的数据。最后递归执行上述操作,直到数组长度<=1;

2特点:快速,常用。缺点是需要另外声明两个数组,浪费了内存空间资源。

3实现:

var times=0;var quickSort=function(arr){     //如果数组长度小于等于1无需判断直接返回即可    if(arr.length<=1){        return arr;    }    var midIndex=Math.floor(arr.length/2);//取基准点    var midIndexVal=arr.splice(midIndex,1);//取基准点的值,splice(index,1)函数可以返回数组中被删除的那个数arr[index+1]    var left=[];//存放比基准点小的数组    var right=[];//存放比基准点大的数组    //遍历数组,进行判断分配    for(var i=0;i

 

4效率:数组长度10,排序次数22次。

 

三:总结

两种方法各有优缺点,但是这两种方法作为程序员必须掌握,因为一种是最基础的,另一种是最常用的,面试或者日常都会碰到。

转载于:https://www.cnblogs.com/dtdxrk/p/6758402.html

你可能感兴趣的文章
Unity 3D 我来了
查看>>
setup elk with docker-compose
查看>>
C++ GUI Qt4学习笔记03
查看>>
Java基础回顾 —反射机制
查看>>
c# 前台js 调用后台代码
查看>>
2017-02-20 可编辑div中如何在光标位置添加内容
查看>>
$.ajax()方法详解
查看>>
jquery操作select(增加,删除,清空)
查看>>
Sublimetext3安装Emmet插件步骤
查看>>
MySQL配置参数
查看>>
全面理解Java内存模型
查看>>
存储过程
查看>>
生成器
查看>>
将一个数的每一位都取出来的方法!
查看>>
2) 十分钟学会android--建立第一个APP,执行Android程序
查看>>
面试题8:二叉树下的一个节点
查看>>
hash冲突的解决方法
查看>>
Asp.Net webconfig中使用configSections的用法
查看>>
mysql 二进制日志
查看>>
阻止putty变成inactive
查看>>