JS中数据结构与算法---排序算法(Sort Algorithm)实例详解


Posted in Javascript onJune 17, 2019

排序算法的介绍

排序也称排序算法 (Sort Algorithm),排序是将 一组数据依指定的顺序 进行 排列的过程

排序的分类

1)  内部排序 : 指将需要处理的所有数据都加载 到 内部存储器(内存) 中进行排序。

2) 外部排序法: 数据量过大,无法全部加载到内 存中,需要借助 外部存储(文件等) 进行 排序。

常见的排序算法分类

JS中数据结构与算法---排序算法(Sort Algorithm)实例详解

算法的时间复杂度 度量一个程序(算法)执行时间的两种方法

1、事后统计的方法 这种方法可行, 但是有两个问题:一是要想对设计的算法的运行性能进行评测,需要实际运行该程序;

二是所得时间的统计量依赖于计算机的硬件、软件等环境因素 , 这种方式,要在同一台计算机的相同状态下运行,才能比较那个算法速度更快。

2、事前估算的方法 通过分析某个算法的时间复杂度来判断哪个算法更优.

时间频度

时间频度:一个算法花费的时间与算法中语句的执行次数成正比例,哪个算法中语句执行次数多,它花费时间就多。一个算法中的语句执行次数称为语句频度或时间频度。记为T(n)。

举例说明-基本案例

比如计算1-100所有数字之和, 我们设计两种算法:

JS中数据结构与算法---排序算法(Sort Algorithm)实例详解

JS中数据结构与算法---排序算法(Sort Algorithm)实例详解

JS中数据结构与算法---排序算法(Sort Algorithm)实例详解

JS中数据结构与算法---排序算法(Sort Algorithm)实例详解

时间复杂度

1、一般情况下,算法中的基本操作语句的重复执行次数是问题规模n的某个函数,用T(n)表示,若有某个辅助函数f(n),使得当n趋近于无穷大时,T(n) / f(n) 的极限值为不等于零的常数,则称f(n)是T(n)的同数量级函数。记作 T(n)=O( f(n) ),称O( f(n) )  为算法的渐进时间复杂度,简称时间复杂度。

2、T(n) 不同,但时间复杂度可能相同。 如:T(n)=n²+7n+6 与 T(n)=3n²+2n+2 它们的T(n) 不同,但时间复杂度相同,都为O(n²)。

3、计算时间复杂度的方法:

用常数1代替运行时间中的所有加法常数  T(n)=n²+7n+6 => T(n)=n²+7n+1 修改后的运行次数函数中,只保留最高阶项  T(n)=n²+7n+1 => T(n) = n² 去除最高阶项的系数 T(n) = n² => T(n) = n² => O(n²) 常见的时间复杂度

JS中数据结构与算法---排序算法(Sort Algorithm)实例详解

说明:

常见的算法时间复杂度由小到大依次为: Ο(1)<Ο(log 2 n)<Ο(n)<Ο(nlog 2 n)<Ο(n 2 )<Ο(n 3 )< Ο(n k ) <Ο(2 n ) ,随着问题规模n的不断增大,上述时间复杂度不断增大,算法的执行效率越低

从图中可见,我们应该尽可能避免使用指数阶的算法

时间复杂度示例介绍 1)常数阶O(1)

无论代码执行了多少行,只要是没有循环等复杂结构,那这个代码的时间复杂度就都是O(1)

JS中数据结构与算法---排序算法(Sort Algorithm)实例详解

上述代码在执行的时候,它消耗的时候并不随着某个变量的增长而增长,那么无论这类代码有多长,即使有几万几十万行,都可以用O(1)来表示它的时间复杂度。

2)对数阶O(log 2 n)

JS中数据结构与算法---排序算法(Sort Algorithm)实例详解

说明:在while循环里面,每次都将 i 乘以 2,乘完之后,i 距离 n 就越来越近了。假设循环x次之后,i 就大于 2 了,此时这个循环就退出了,也就是说 2 的 x 次方等于 n,那么 x = log 2 n也就是说当循环 log 2 n 次以后,这个代码就结束了。因此这个代码的时间复杂度为:O(log 2 n)  。 O(log 2 n) 的这个2 时间上是根据代码变化的,i = i * 3 ,则是 O(log 3 n) .

JS中数据结构与算法---排序算法(Sort Algorithm)实例详解

3)线性阶O(n)

JS中数据结构与算法---排序算法(Sort Algorithm)实例详解

说明:这段代码,for循环里面的代码会执行n遍,因此它消耗的时间是随着n的变化而变化的,因此这类代码都可以用O(n)来表示它的时间复杂度

4)线性对数阶O(nlogN)

JS中数据结构与算法---排序算法(Sort Algorithm)实例详解

说明:线性对数阶O(nlogN) 其实非常容易理解,将时间复杂度为O(logn)的代码循环N遍的话,那么它的时间复杂度就是 n * O(logN),也就是了O(nlogN)

5)平方阶O(n²)

JS中数据结构与算法---排序算法(Sort Algorithm)实例详解

说明:平方阶O(n²) 就更容易理解了,如果把 O(n) 的代码再嵌套循环一遍,它的时间复杂度就是 O(n²),这段代码其实就是嵌套了2层n循环,它的时间复杂度就是 O(n*n),即  O(n²) 如果将其中一层循环的n改成m,那它的时间复杂度就变成了 O(m*n)

6)立方阶O(n³)、K次方阶O(n^k)

说明:参考上面的O(n²) 去理解就好了,O(n³)相当于三层n循环,其它的类似

平均时间复杂度和最坏时间复杂度 平均时间复杂度是指所有可能的输入实例均以等概率出现的情况下,该算法的运行时间。 最坏情况下的时间复杂度称最坏时间复杂度。 一般讨论的时间复杂度均是最坏情况下的时间复杂度。  这样做的原因是:最坏情况下的时间复杂度是算法在任何输入实例上运行时间的界限,这就保证了算法的运行时间不会比最坏情况更长。 平均时间复杂度和最坏时间复杂度是否一致,和算法有关(如图:)。

JS中数据结构与算法---排序算法(Sort Algorithm)实例详解

算法的空间复杂度简介 类似于时间复杂度的讨论,一个算法的空间复杂度(Space Complexity)定义为该算法所耗费的存储空间,它也是问题规模n的函数。 空间复杂度(Space Complexity)是对一个算法在运行过程中临时占用存储空间大小的量度。有的算法需要占用的临时工作单元数与解决问题的规模n有关,它随着n的增大而增大,当n较大时,将占用较多的存储单元,例如快速排序和归并排序算法就属于这种情况 在做算法分析时, 主要讨论的是时间复杂度从用户使用体验上看,更看重的程序执行的速度 。一些缓存产品(redis, memcache)和算法(基数排序)本质就是 用空间换时间.

总结

以上所述是小编给大家介绍的JS中数据结构与算法---排序算法(Sort Algorithm)实例详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Javascript 相关文章推荐
JavaScript读取中文cookie时的乱码问题的解决方法
Oct 14 Javascript
公共js在页面底部加载的注意事项介绍
Jul 18 Javascript
解决Extjs4中form表单提交后无法进入success函数问题
Nov 26 Javascript
JavaScript中this关键词的使用技巧、工作原理以及注意事项
May 20 Javascript
Javascript 读取操作Sql中的Xml字段
Oct 09 Javascript
Jquery判断form表单数据是否变化
Mar 30 Javascript
浅谈javascript中的加减时间
Jul 12 Javascript
ES6新特性之数组、Math和扩展操作符用法示例
Apr 01 Javascript
JS复杂判断的更优雅写法代码详解
Nov 07 Javascript
Electron-vue开发的客户端支付收款工具的实现
May 24 Javascript
使用Webpack提升Vue.js应用程序的4种方法(翻译)
Oct 09 Javascript
vue-property-decorator用法详解
Dec 12 Javascript
详解element-ui设置下拉选择切换必填和非必填
Jun 17 #Javascript
JS实现的字符串数组去重功能小结
Jun 17 #Javascript
JavaScript静态作用域和动态作用域实例详解
Jun 17 #Javascript
深入解析koa之中间件流程控制
Jun 17 #Javascript
深入解读Node.js中的koa源码
Jun 17 #Javascript
学习RxJS之JavaScript框架Cycle.js
Jun 17 #Javascript
javascript系统时间设置操作示例
Jun 17 #Javascript
You might like
php smarty 二级分类代码和模版循环例子
2011/06/01 PHP
WordPress自定义时间显示格式
2015/03/27 PHP
CakePHP框架Model关联对象用法分析
2017/08/04 PHP
PHP实现带进度条的Ajax文件上传功能示例
2019/07/02 PHP
PHP 判断字符串是中文还是英文, 或者是中英混合
2021/03/09 PHP
javascript  Error 对象 错误处理
2008/05/18 Javascript
javascript 简练的几个函数
2009/08/29 Javascript
javascript在myeclipse中报错的解决方法
2013/10/29 Javascript
基于jQuery实现最基本的淡入淡出效果实例
2015/02/02 Javascript
js将滚动条滚动到指定位置的简单实现方法
2016/06/25 Javascript
微信小程序 基础知识css样式media标签
2017/02/15 Javascript
javascript九宫格图片随机打乱位置的实现方法
2017/03/15 Javascript
JS jQuery使用正则表达式去空字符的简单实现代码
2017/05/20 jQuery
JS身份证信息验证正则表达式
2017/06/12 Javascript
JS+Ajax实现百度智能搜索框
2017/08/04 Javascript
详解Vue路由自动注入实践
2019/04/17 Javascript
微信网页登录逻辑与实现方法
2019/04/29 Javascript
小程序实现短信登录倒计时
2019/07/12 Javascript
小程序中手机号识别的示例
2020/12/14 Javascript
详解vite+ts快速搭建vue3项目以及介绍相关特性
2021/02/25 Vue.js
python网络编程之TCP通信实例和socketserver框架使用例子
2014/04/25 Python
Python编程实现蚁群算法详解
2017/11/13 Python
简述:我为什么选择Python而不是Matlab和R语言
2017/11/14 Python
简单了解django orm中介模型
2019/07/30 Python
基于Python编写一个计算器程序,实现简单的加减乘除和取余二元运算
2020/08/05 Python
俄罗斯最大的隐形眼镜销售网站:Ochkov.Net
2021/02/07 全球购物
捷克建筑材料网上商店:DEK.cz
2021/03/06 全球购物
大专应届生个人简历的自我评价
2013/10/15 职场文书
给排水工程师岗位职责
2013/11/21 职场文书
初一体育教学反思
2014/01/29 职场文书
戒毒悔改检讨书
2014/09/21 职场文书
街道党工委党的群众路线教育实践活动对照检查材料思想汇报
2014/10/05 职场文书
2014年机关工会工作总结
2014/12/19 职场文书
2015年上半年信访工作总结
2015/03/30 职场文书
辞职信怎么写?
2019/05/21 职场文书
分享CSS盒子模型隐藏的几种方式
2022/02/28 HTML / CSS