Hello!我是super喵二~~~今天练了几道面试题,突然觉得好久没有好好归纳 过排序算法了。以前都是用C/java编写排序,这次用js来总结下五大排序算法吧:

1、冒泡排序(常用及常考排序算法):

  不用多说,冒泡就是一个一个浮上去~~~也就是说需要一个一个比较:

<script type="text/javascript">
//冒泡排序,一次一次的相邻两个数比,直到把最大数找出来
var array = [5,2,4,6,8];
var temp;
function sort(array){
for(var i=0;i<array.length-1;i++){
for(var j=0;j<array.length-i-1;j++){
if(array[j]>array[j+1]){
temp=array[j+1];
array[j+1]=array[j];
array[j]=temp;
}
}
}
console.log(array);
} sort(array) // [2,4,5,6,8]
</script>

Bubble

2、插入排序:

  插入插入,当然需要插在该插的位置啦。简单理解就是每循环到一个数,就把它前面的数当做一个数组,然后插在数组里该插的位置:

<script type="text/javascript">
var array = [5,2,4,6,8];
var temp;
//插入排序是从第一个数开始,把第一个当成数组,第二个数与它比较,插入。再将前两个看成数组,第三个来比较插入该插的位置,依次类推
function sort(array){
for(var i=0;i<array.length;i++){
for(var j=0;j<i+1;j++){
if(array[i]<array[j]){
temp=array[i];
array[i]=array[j];
array[j]=temp;
}
}
}
console.log(array);
} sort(array) // [2,4,5,6,8]
</script>

Insert

3、选择排序:

  一次一次选择出小的数(按升序来的话),首先认为第一个数最小,就依次比较它后面的数,有更小的就记录位置,将这个更小的记录之后,如果后面还有数,就以这个更小数为基准,再继续找,如果有比更小还小的,就记录位置,然后继续找,直到找到最小的然后和第一个数交换。接下来就从数组中的第二个数开始,依次~~~~

  

<script type="text/javascript">
var array = [5,2,4,6,8];
var temp;
//选择排序,从第一个数开始比较,遇到小与它的记录位置,再将这个数与它后面的数比较,如果没有就交换这两个数,如果有,则继续比较。
function sort(array){
for(var i=0;i<array.length-1;i++){
var index=i;
for(var j=i+1;j<array.length;j++){
if(array[index]>array[j]){
index=j;
} }
temp=array[i];
array[i]=array[index];
array[index]=temp
}
console.log(array);
} sort(array) // [2,4,5,6,8]
</script>

Select

4、快速排序:

  快速排序,众所周知,速度最快,很多公司面试都会考这个,手写的话还是有点难。大家可以主要掌握下C语言版本,用其他语言写就很容易了。。。我是参照阮一峰老师写的,主要是找一个基准元素,比基准元素小的在左边,比基准元素大的在右边,然后左右看成两个数组,分别找各自的基准元素再分组~~~直到最后~~

<script type="text/javascript">
var array = [5,2,4,6,8];
var temp;
//快速排序:先找一个基准元素,比它小的放在左边数组,大的放在右边数组,然后又分别在左边和右边数组中找出基准元素进行比较
var quicksort=function(array){
if (array.length<=1) {
return array;
}else{
var priotIndex=Math.floor(array.length/2);
var priot=array.splice(priotIndex,1)[0];
var left=[];
var right=[];
for (var i = 0; i < array.length; i++) {
if (array[i]<priot) {
left.push(array[i]);
}
else {
right.push(array[i]);
}
}
return quicksort(left).concat([priot],quicksort(right));
}
} console.log(quicksort(array)); </script>

Quick

5、合并排序:

  合并排序类似快排,主要也是才用递归,分组比再合,具体实现如下:

//归并排序:从两个两个比较,然后四个一组比较,然后8个一组比较
var array = [5,2,4,6,8];
var merge=function(left,right){
var arr=[];
while(left.length>0&&right.length>0){
if (left[0]<right[0]) {
arr.push(left.shift());
}else{
arr.push(right.shift());
}
}
return arr.concat(left,right);
} var mergeSort=function(array){
if (array.length==1) {
return array;
}else if (array.length>1) {
var middle=Math.floor(array.length/2),
left=array.slice(0,middle),
right=array.slice(middle);
return merge(mergeSort(left),mergeSort(right)); }
} console.log(mergeSort(array));

Merge

暂时就这五个,排序算法还有很多种,堆排序,随机快排。。。。这就自行了解吧,还有比较每个算法的时间复杂度,空间复杂度来决定谁更好,视情况而定吧~~

几大排序思想(由javascript编写)的更多相关文章

  1. 转载部长一篇大作:常用排序算法之JavaScript实现

    转载部长一篇大作:常用排序算法之JavaScript实现 注:本文是转载实验室同门王部长的大作,找实习找工作在即,本文颇有用处!原文出处:http://www.cnblogs.com/ywang172 ...

  2. JavaScript编写了一个计时器

    初学JavaScript,用JavaScript编写了一个计时器. 设计思想: 1.借助于Date()对象,来不断获取时间点: 2.然后用两次时间点的毫秒数相减,算出时间差: 3.累加时间差,这样就能 ...

  3. JavaScript 排序算法(JavaScript sorting algorithms)

    JavaScrip 排序算法(JavaScript Sorting Algorithms) 基础构造函数 以下几种排序算法做为方法放在构造函数里. function ArrayList () { va ...

  4. JavaScript 编写随机四位数验证码(大小写字母和数字)

    1.JavaScript编写随机四位数验证码,用到的知识点为: a.Math对象的随机数:Math.random() b.Math对象的取整    :Math.floor() c.处理所需要的下标个数 ...

  5. artDialog是一个基于javascript编写的对话框组件,它拥有精致的界面与友好的接口

    artDialog是一个基于javascript编写的对话框组件,它拥有精致的界面与友好的接口 自适应内容 artDialog的特殊UI框架能够适应内容变化,甚至连外部程序动态插入的内容它仍然能自适应 ...

  6. Codeforces 588E. A Simple Task (线段树+计数排序思想)

    题目链接:http://codeforces.com/contest/558/problem/E 题意:有一串字符串,有两个操作:1操作是将l到r的字符串升序排序,0操作是降序排序. 题解:建立26棵 ...

  7. 用Javascript编写Chrome浏览器插件

    原文:http://homepage.yesky.com/62/11206062.shtml 用Javascript编写Chrome浏览器插件 2010-04-12 07:30 来源:天极网软件频道 ...

  8. javascript 编写的贪吃蛇

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  9. three.js是JavaScript编写的WebGL第 三方库

    three.js是JavaScript编写的WebGL第 三方库.提供了非常多的3D显示功能.Three.js 是一款运行在浏览器中的 3D 引擎,你可以用它创建各种三维场景,包括了摄影机.光影.材质 ...

随机推荐

  1. php数组--2017-04-16

    一.定义数组 (1)索引数组 $arr=array(1,2,3,3); (2)关联数组  类似于集合 $arr1=array("one"=>"111",& ...

  2. NOIP2009T3最优贸易

    洛谷传送门 看到这个题,原本想先从后往前dfs,求出能到终点的点,再在这些点里从前往后spfa,用一条边上的两个城市的商品价格的差来作边权,实施过后,发现图中既有负边权,又有回路,以及各种奇奇怪怪的东 ...

  3. Java设计模式:工厂模式

    问题提出 Java的工厂模式与现实生活中的工厂的模型是很相似的.工厂是用来做什么?当然是用来生成产品.因此在Java的工厂模式的关键点就是如何描述好产品和工厂这2个角色之间的关系. 下面来仔细描述一下 ...

  4. 【转】JDBC学习笔记(7)——事务的隔离级别&批量处理

    转自:http://www.cnblogs.com/ysw-go/ 数据库事务的隔离级别 对于同时运行的多个事务, 当这些事务访问数据库中相同的数据时, 如果没有采取必要的隔离机制, 就会导致各种并发 ...

  5. CF #284 div1 D. Traffic Jams in the Land 线段树

    大意是有n段路,每一段路有个值a,通过每一端路需要1s,如果通过这一段路时刻t为a的倍数,则需要等待1s再走,也就是需要2s通过. 比较头疼的就是相邻两个数之间会因为数字不同制约,一开始想a的范围是2 ...

  6. rsync远程同步

    一.概念 Rsync是一个开源的快速备份工具,可以在不同主机之间镜像同步整个目录树,支持增量备份,保持连接和权限,且采用优化的同步算法,传输前执行压缩,因此非常适用于异地备份,镜像服务器等应用.rsy ...

  7. Android 正则表达式验证手机号、姓名(包含少数民族)、身份证号

    最近项目中新增的功能,需要对手机号.姓名.身份证号等一些信息进行验证,最好的方法是通过正则表达式来验证,网上查了一些资料,写了这几个工具方法. 1.验证手机号 规则:第一位只能是1,第二位为3-8中的 ...

  8. 新建Android项目,会出现两个项目一个是自己创建的项目,另一个是“appcompat_v7”项目,这是怎么回事呢?该怎么解决呢?

    做Android开发的朋友最近会发现,更新ADT至22.6.0版本之后,创建新的安装项目,会出现appcompat_v7的内容.并且是创建一个新的内容就会出现.这到底是怎么回事呢?原来appcompa ...

  9. Cocos2d-x 3.2 环境搭建

    参考文章地址: 1.Cocos2d-x官方安装说明文档:http://cn.cocos2d-x.org/tutorial/show?id=781 2.CSDN博客:http://blog.csdn.n ...

  10. 转:Linux中文显示乱码?如何设置centos显示中文

    怎么设置Linux系统中文语言,这是很多小伙伴在开始使用Linux的时候,都会遇到一个问题,就是终端输入命令回显的时候中文显示乱码.出现这个情况一般是由于没有安装中文语言包,或者设置的默认语言有问题导 ...