JavaScript实现冒泡排序、快速排序、插入排序
JavaScript实现冒泡排序、快速排序、插入排序
时间:2014-01-09 18:05:51 来源: 作者:胡晗
冒泡排序的基本思想:所谓冒泡就是泡泡一个一个往上冒,让体积最轻的泡泡浮在最上面,然后按照重量往下依次排列。
var a=[12,3,43,11,56,90,7,66,82];
拿上面的数组a举例,做一个升序排序。第一轮循环我们得把值最大的数从数组中找出来放在数组最后,即索引为a.length-1的位置。也就是从a[0]开始,依次往后比较相邻两个数的大小。
首先是a[0]和a[1]比较,如果a[0]>a[1],则交换两个数的位置,反之则不交换。a[0]是12,a[1]是3,所以得交换位置,交换完位置之后的数组是[3,12,43,11,56,90,7,66,82],然后比较a[1]和a[2],(a[1]=12)< (a[2]=43),不用交换位置,同理往后比较a[2]和a[3],(a[2]=43)>(a[3]=11),交换位置,此时的数组a为[3,12,11,43,56,90,7,66,82],以此类推,如果a[j]>a[j+1]就交换值,否则,继续往后。
注意:两个变量交换数据,一般情况下需要一个中介变量。比如:var a="a",b="b";让a和b交换值,需要一个中介变量:var temp=a;a=b;b=temp;这样
第一轮外层循环完之后,我们得到的数组a为[3,12,11,43,56,7,66,82,90],把值最大的90放在了数组的末尾。
第二次外层循环,我们只需要比较到a.length-2的位置即可,因为最后一项a[a.length-1]已经确定了(90)。第三次外层循环,我们需要比较到a.length-3的位置,所以内重循环j的值为j< a.length-1-i,通过两重循环,冒泡排序就完成了。
function bubbleSort(arr){
var n=arr.length; //获取数组的长度,即有n个数在排序
var temp=null; //定义一个临时变量,交换数据用
for(var i=0; i<n-1; i++){ //外层循环n-1次
for(var j=0; j<n-1-i; j++){ //内层每次循环n-1-i次,每次循环完,都能从剩下的数当中找出一个最大的放在n-1-i的位置
if(arr[j]>arr[j+1]){ //如果a[j]>a[j+1]则交换位置
temp=arr[j];
arr[j]=arr[j+1];
arr[j+1]=temp;
}
}
}
return arr; //返回排好序的数组
}
冒泡排序优化:
function bubbleSort(arr){
var n=arr.length;
var temp=null;
var flag=false;//设置标志位,初始值为false
for(var i=0; i<n-1; i++){
for(var j=0; j<n-1-i; j++){
if(arr[j]>arr[j+1]){
temp=arr[j];
arr[j]=arr[j+1];
arr[j+1]=temp;
flag=true;//只要交换了标识就设为true
}
}
if(flag){//只要交换了位置,flag的值就重新设置为false
flag=false;
}else{//如果没有交换,说明数组已经排好序,可以结束循环了
break;
}
}
return arr;
}
快速排序的基本思想:首先从数组a中选取一个基准点(通常我们取中间项作为基准点),然后遍历数组,把小于基准点的项放到基准点左边集合,把大于基准点的项放到基准点右边集合。再对左边和右边两个集合重复前面的操作,直到每个子集就剩下一个元素。其实就是一个递归的思想。
依旧拿数组a=[12,3,43,11,56,90,7,66,82]举例,我们先选取一个基准点pivot=a[Math.floor(a.length/2)],即a[4]值为56,然后便利数组中的剩余项,把小于56的数组项放在左边的数组left中,把大于等于56的数组项放在右边的数组right中,第一轮操作结束后left=[12,3,43,11,7],right=[90,66,82],然后再对left和right重复以上的操作,直到left和right仅剩一项或为空时结束。最后返回left+pivot+right。
function quickSort(arr){
var len=arr.length;//获取arr的长度
if(len<=1){//如果arr的长度小于等于1则直接返回arr
return arr;
}
var pIndex=Math.floor(len/2);//获取基准点的索引下标
var pivot=arr.splice(pIndex,1);//用splice方法获取基准点pivot=[arr[pIndex]],此时的arr为去除第pIndex项之后的剩余项;
var left=[];
var right=[];
for(var i=0; i<arr.length; i++){
if(arr[i]<pivot[0]){//如果小于基准点就放到数组l中
left.push(arr[i]);
}else{//如果大于等于基准点就放到右边数组中
right.push(arr[i]);
}
}
return quickSort(left).concat(pivot,quickSort(right));//递归不断重复整个过程
}
插入排序的基本思想:首先选取数组的第一项即a[0],我们可以认为这个数是已经排好序的,再取a[1]项插入到已经排好序的元素中,此时只有a[0],所以我们需要比较a[1]和a[0]的大小。如果a[1]<a[0],则需要把a[1]先用一个临时变量temp保存,a[0]往后挪一位(即a[1]的位置),然后把temp赋值给a[0]。要插入的元素依次为a[1]-a[a.length-1]项,插入每一项时,都需要从后往前遍历已排好序的元素,如果已排好序的元素比要插入的元素大,则把该元素往后挪一位,直到已排好的元素小于等于要插入的元素(或者已经遍历完了已排好序的数组项),则把要插入的元素放入该位置+1的索引中(或者放在数组的第0个位置)。对每个插入项都执行上面的操作,则最后的数组就排好序了。
function insertSort(arr){
var temp=null;//定义一个临时变量保存要插入元素的值
for(var i=1; i<arr.length; i++){//从索引位置1开始遍历数组
if(arr[i]<arr[i-1]){//只有要插入的元素小于已排好序的最大元素的时候才需要进行下面的操作
temp=arr[i];//把要插入的元素赋给一个临时变量
var p=i-1;//已排好序的数组的最后一项索引为i-1
while(temp<arr[p] && p>=0){//如果要插入的元素小于已排好序的元素并且没有到已排好数组的开始位置
arr[p+1]=arr[p];//把大于要插入元素(temp)的已排好序元素位置往后挪一位
p--;//从后往前便利已经排好序的元素
}
arr[p+1]=temp;//把要插入的元素插入到已排好序的数组中,索引位置为p+1
}
}
return arr;//返回已排好序的数组
}
JavaScript实现冒泡排序、快速排序、插入排序的更多相关文章
- javascript的冒泡排序, 快速排序, 选择排序, 插入排序
冒泡排序, 最经典的排序, 把比较大的数字往后放, 和选择排序恰恰相反: <!DOCTYPE html> <html lang="en"> <head ...
- JavaScript 数据结构与算法之美 - 冒泡排序、插入排序、选择排序
1. 前言 算法为王. 想学好前端,先练好内功,只有内功深厚者,前端之路才会走得更远. 笔者写的 JavaScript 数据结构与算法之美 系列用的语言是 JavaScript ,旨在入门数据结构与算 ...
- 算法与数据结构(十三) 冒泡排序、插入排序、希尔排序、选择排序(Swift3.0版)
本篇博客中的代码实现依然采用Swift3.0来实现.在前几篇博客连续的介绍了关于查找的相关内容, 大约包括线性数据结构的顺序查找.折半查找.插值查找.Fibonacci查找,还包括数结构的二叉排序树以 ...
- 冒泡排序与插入排序(C#实现)
本人应届生面试,发现被问了2次关于排序的算法.当时竟然没写出来!!!好吧,可能是用库函数多了,很久没搞算法了,在纸上写没感觉吧. 今天花了1个多小时写了下冒泡排序与插入排序(C#实现),并写了注释和小 ...
- Javascript中的冒泡排序,插入排序,选择排序,快速排序,归并排序,堆排序 算法性能分析
阿里面试中有一道题是这样的: 请用JavaScript语言实现 sort 排序函数,要求:sort([5, 100, 6, 3, -12]) // 返回 [-12, 3, 5, 6, 100],如果你 ...
- JavaScript新手学习笔记3——三种排序方式(冒泡排序、插入排序、快速排序)
每种编程语言学到数组的时候,都会讲到排序算法,当时学C语言的时候,卡在排序算法.今天来总结一下javascript中如何实现三种排序算法. 1.冒泡排序(默认升序排列哦) 原理: 冒泡排序的原理,顾名 ...
- JS实现冒泡排序,插入排序和快速排序(从input中获取内容)
以前参加面试的时候,被问到过让用JS实现一个快速排序,当时太年轻,并没有回答上来. 于是,这里便把三种排序都用JS来做了一下.结合html,从input文本框中获取输入进行排序. 关于这几种算法的原理 ...
- 【C++】冒泡排序、插入排序、快速排序
#include<iostream> using namespace std; void BubbleSort(int *a,int istart,int len)//冒泡排序 { //a ...
- 用js实现算法:冒泡排序、插入排序和快速排序
一.冒泡排序 function bubbleSort(arr){ for(var i=0;i<arr.length;i++){ for(var j=0;j<arr.length-i-1;j ...
随机推荐
- Servlet&jsp基础:第四部分
声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...
- [JAVA设计模式]第四部分:行为模式
声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...
- Spark Streaming官方文档学习--下
Accumulators and Broadcast Variables 这些不能从checkpoint重新恢复 如果想启动检查点的时候使用这两个变量,就需要创建这写变量的懒惰的singleton实例 ...
- XmlDocument To String
一.从String xml到XmlDocument的: string xml = "<XML><Test>Hello World</Test></X ...
- Typescript的面向对象
封装: var Greeter = (function () { function Greeter(message) { this.greeting = message; } Greeter.prot ...
- 10款Windows命令行工具
Windows下CMD不好用,远没有Linux,或者一些SSH工具用起来方便.其实Windows下,也有一些不错的工具替代CMD: 0.powercmd经过比较,我最终选择了这款,这里补充一下截图:
- Spring的DI(Ioc) - 注入bean 和 基本数据类型
注入bean有两种方式: 注入其他bean: 方式一 <bean id="orderDao" class="cn.itcast.service.OrderDaoBe ...
- Maven仓库构建
什么是Maven仓库 在不用Maven的时候,比如说以前我们用Ant构建项目,在项目目录下,往往会看到一个名为/lib的子目录,那里存放着各类第三方依赖jar文件,如log4j.jar,junit.j ...
- Android_Nexus4_屏幕截图
1. 一般都是 音量-键 + 电源键,同时按一秒以上 2. 3.
- [转]ubuntu下安装程序的三种方法
出处:http://www.cnblogs.com/xwdreamer/p/3623454.html 引言 在ubuntu当中,安装应用程序我所知道的有三种方法,分别是apt-get,dpkg安装de ...