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. 【2017-04-18】Ado.Net C#连接数据库进行增、删、改、查

    一.简介 1.ado.net是一门数据库访问技术. 他可以通过程序来操作数据库 2.类库 Connection 类 和数据库交互,必须连接它.连接帮助指明数据库服务器.数据库名字.用户名.密码,和连接 ...

  2. Vue 事件驱动和依赖追踪

    之前关于 Vue 数据绑定原理的一点分析,最近需要回顾,就顺便发到随笔上了 在之前实现一个自己的Mvvm中,用 setter 来观测model,将界面上所有的 viewModel 绑定到 model ...

  3. 使用validator-api来验证spring-boot的参数

    作为服务端开发,验证前端传入的参数的合法性是一个必不可少的步骤,但是验证参数是一个基本上是一个体力活,而且冗余代码繁多,也影响代码的可阅读性,所以有没有一个比较优雅的方式来解决这个问题? 这么简单的问 ...

  4. 服务器端IIS中部署带Office组件程序

    开发的程序需要用到Office组件(Word.Excel等)的时候,往往在开发环境中运行正常,但是部署到服务器上就出问题. 1)首先保证开发环境引用的dll正确 .net 4.0以上版本,添加引用Mi ...

  5. poj 1001 分析

    1) n = 0; return 1: 2) n = 1; bool standardizeNumNoDot(string &s){标准化是一定要得} _将‘.’前后的〇全部去除,正常retu ...

  6. TCP协议总结

    TCP的特性 TCP提供一种面向连接的.可靠的字节流服务 在一个TCP连接中,仅有两方进行彼此通信.广播和多播不能用于TCP TCP使用校验和,确认和重传机制来保证可靠传输 TCP给数据分节进行排序, ...

  7. PHP获取Mp3文件信息

    扫描本地MP3文件,获取文件信息

  8. [原创]Jquery实现表格内容点击隐藏显示内容

    1.首先看效果,点击红色字体,可是查看全部文字内容 2.JS实现 思路:将Ajax获得的数据,一份截取,一份不变,放到td里面,分别用span装着. 然后通过display属性,进行切换

  9. 异步工作流控制-condCall

    在JavaScript编程中,异步操作一直是一个问题,回调是一种深层次的嵌套处理方式,我们也可以把嵌套处理转为直线处理以简化异步处理.有过prolog和erlang编程了解的同学可能对模式匹配有深刻的 ...

  10. 适配器模式(Adpater Pattern)

    适配器模式把一个类的接口变换成客户端所期待的另一种接口,从而使原本因接口不匹配而无法在一起工作的两个类能够在一起工作. 适配器模式的用途 用电器做例子,笔记本电脑的插头一般都是三相的,即除了阳极.阴极 ...