重温前端基础之-js排序算法
javascript数组常用的方法:
push():返回值,数组新的长度
pop():返回值,被删除的数组末尾元素
shift():返回值,被删除的数组首部元素
unshift():返回值,数组新的长度
concat():返回值,拼接后新的数组
slice():返回值,截取的新的数组
splice():返回值,被插入/删除/替换元素的数组
map():返回新的数组
filter():返回被筛选后的新的数组
reduce():返回新的数组
sort():返回排序后的新的数组
与数组有关的两个:
join():将数组转化为用特殊符号分割的字符串
reverse():将数组顺序逆转
不常用的:
every()
some()
//1、使用sort方法进行排序的算法如下:
//字符串排序:
var arr = [George,John,Thomas,James,Adrew,Martin];
arr.sort();
//数字排序:
var arr = [4,3,7,10,15,30,22];
arr.sort(function(a,b){
return a-b>0;
})
//2、冒泡排序:
function bubbbleSort(arr){
if(!Array.isArray(arr)){
return new Error("arr不是数组");
}
if(arr.length<=1){
return arr;
31 }
var temp,i,j;
for(i=0;i<arr.length;i++){
37 for(j=0;j<arr.length-i-1;j++){
if(arr[j]>arr[j+1]){
temp = arr[j];
arr[j] = arr[j+1];
arr[j+1]=temp;
}
}
51 }
return arr;
}
//改进版冒泡排序:(添加一个标志位,可以让已经排过序的不用重复遍历)
function bubbbleSort(arr){
if(!Array.isArray(arr)){
return new Error("arr不是数组");
}
if(arr.length<=1){
return arr;
}
var pos,temp,j;
var i = arr.length-1;//初始时,最后位置保持不变
while(i>0){
76 pos = 0;//每一轮循环,位置从0开始。
for(j=0;j<i;j++){
if(arr[j]>arr[j+1]){
pos = j;
temp = arr[j];
arr[j] = arr[j+1];
arr[j+1]=temp;
}
}
i=pos;
}
return arr;
}
//3、快速排序(原理是,1、找一个基值,一般是数组的中间数,2、然后将大于中间值的数放右边,小于中间值的数放左边,3、然后递归第二步,4返回拼接好排序后的数组)
function quickSort(arr){
if(!Array.isArray(arr)){
return new Error("arr不是数组");
}
if(arr.length<=1){
return arr;
}
var i,left = [],right = [];
var midIndex = Math.floor(arr.length/2);
var midItem = arr.splice(midIndex,1)[0];//此处要把中间值从数组中去掉。
for(i=0;i<arr.length;i++){
if(arr[i]<midItem){
left.push(arr[i]);
}else{
right.push(arr[i]);
}
}
117 return quickSort(left).concat([midItem],quickSort(right));
}
参考文章:http://web.jobbole.com/87968/
重温前端基础之-js排序算法的更多相关文章
- 总结下js排序算法和乱序算法
其实本人最怕的就是算法,大学算法课就感觉老师在讲天书,而且对于前端来说,算法在实际的应用中实在是很有限.毕竟算法要依靠大量的数据为基础才能发挥出算法的效率,就浏览器那性能,......是吧,退一万步说 ...
- js排序算法汇总
JS家的排序算法 十大经典算法排序总结对比 一张图概括: 主流排序算法概览 名词解释: n: 数据规模k:“桶”的个数In-place: 占用常数内存,不占用额外内存Out-place: 占用额外 ...
- 排序图解:js排序算法实现
之前写过js实现数组去重, 今天继续研究数组: 排序算法实现. 排序是数据结构主要内容,并不限于语言主要在于思想:大学曾经用C语言研究过一段时间的排序实现, 这段时间有空用JS再将排序知识点熟悉一遍. ...
- 常用的 JS 排序算法整理
关于排序算法的问题可以在网上搜到一大堆,但是纯 JS 版比较零散,之前面试的时候特意整理了一遍,附带排序效率比较. //1.冒泡排序 var bubbleSort = function(arr) { ...
- 自己写的JS排序算法
这学期刚刚学完数据结构,之前就自己写了一点东西,现在整理一下. <!DOCTYPE html> <html> <head> <meta charset=&qu ...
- js排序算法总结—冒泡,快速,选择,插入,希尔,归并
相信排序是任何一个程序猿都会用到的东西,今天简单总结记录下常见的排序算法. 一.冒泡排序 说起冒泡排序,可能每个人都不会陌生,实现思路相当简单明了,就是不停的对数组进行两两比较,将较大(较小)的一项放 ...
- js排序算法总结——冒泡,快速,选择,插入,希尔,归并
相信排序是任何一个程序猿都会用到的东西,今天简单总结记录下常见的排序算法. 一.冒泡排序 说起冒泡排序,可能每个人都不会陌生,实现思路相当简单明了,就是不停的对数组进行两两比较,将较大(较小)的一项放 ...
- 结构-行为-样式-Js排序算法之 直接插入排序
最新因工作原因需要接触到算法,之前学习C++的时候有接触过算法,Javascript中实现算法其实也是大同小异.下面我讲下第一个实现的排序算法--直接插入排序.基本实现思路:假定一个数组中前n(n&g ...
- js排序算法总结
快速排序 大致分三步: 1.找基准(一般是以中间项为基准) 2.遍历数组,小于基准的放在left,大于基准的放在right 3.递归 快速排序的平均时间复杂度是O(nlogn),最差情况是O(n²). ...
随机推荐
- JavaScript中数组的迭代方法:forEach、map、filter、reduce、every、some、for in、for of
JavaScript中有非常多数组迭代方法,这里基本上吧所有的都介绍全了,我项目中比较喜欢的是forEach. 7.for in (for-in循环实际是为循环对象而设计的,for in也可以循环数组 ...
- Windows下获取Dump文件以及进程下各线程调用栈的方法总结(转)
1. Dump文件的用途 Dump文件, 主要用于诊断一个进程的运行状态,尤其是碰到崩溃(Crash)或者挂起(hang)不响应时,需要分析它的工作状态. 除了平时常见的attach到这个进程, 分 ...
- Core篇——初探依赖注入
目录 1.DI&&IOC简单介绍 2.UML类图中六种关联关系 3..net core 中DI的使用 4..net core DI初始化源码初窥 DI&&IOC简单介绍 ...
- Win32 CRT and MFC 清单文件.manifest配制
Demo.exe.manifest <?xml version="1.0" encoding="UTF-8" standalone="yes&q ...
- Core Java(四)
四.数组 数组就是主函数(main方法)中的参数:public static void main(String[] args){ }数组是指一组数据的集合,数组中的每个数据称为元素.在Java中 ...
- word-break属性和css换行显示
这几天在做项目的时候,遇到了比较棘手的问题,便是在一个标签里边展示内容,如果说展示中文汉字,一点问题都没有,但是只要连续展示英文字母或者中文的标点符号(中间不带空格),那么所渲染的内容就不会换行,而是 ...
- CSS3中的2D和3D转换知识介绍
一 2D转换 转换是CSS3中具有颠覆性的特征之一,可以实现元素的位移.旋转.变形.缩放,甚至支持矩阵方式,配合即将学习的过渡和动画知识,可以取代大量之前只能靠Flash才可以实现的效果. 1.移动 ...
- 安装wampserver遇到的问题及解决方案
丢失api-ms-win-crt-runtime-l1-1-0.dll 安装完wampserver,启动服务器的时候遇到一些问题,提示说缺失dll文件,如下图所示: 网上一搜,很多人出现过丢失api- ...
- DDD中 与Dto搭配的AutoMapper插件,摘自《NET企业级应用架构设计》
AutoMapper插件 实现了 DTO与Model的互相映射.
- Qwiklab'实验-CloudFront, EFS, S3'
title: AWS之Qwiklab subtitle: 3. Qwiklab'实验-CloudFront, EFS, S3' date: 2018-09-21 17:29:20 --- Introd ...