8大排序算法总结 JS 实现
//bubble sort
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
|
function bubbleSort(arr,comp){for(var i = 0;i < arr.length; i++){for(var j = 0; j < arr.length - i - 1; j++){if(comp(arr[j],arr[j+1])){exch(arr,j,j+1);}}}}function exch(a,i,j){var tmp = a[i];a[i] = a[j];a[j] = tmp;}var input = new Array(5,1,4,2,3);bubbleSort(input,function(a,b){return a > b;});console.log(input);input = new Array(5,1,4,2,3);bubbleSort(input,function(a,b){return a < b;});console.log(input); |
//selection sort
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
|
function selectionSort(arr,comp){for(var i = 0;i < arr.length ; i++){for(var j = i;j < arr.length ; j++){if(comp(arr[i],arr[j])) { exch(arr,i,j); }}}}function exch(a,i,j){var t = a[i];a[i] = a[j];a[j] = t;}var input = new Array(5,1,4,2,3);selectionSort(input,function(a,b){return a > b;});console.log(input);input = new Array(5,1,4,2,3);bubbleSort(input,function(a,b){return a < b;});console.log(input); |
//insert sort
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
|
function insertSort(arr,comp){var result = new Array();for(;arr.length > 0;){var inserted = false;for(var j = 0;j < result.length; j++){if(comp(result[j],arr[0])) { insert(result,j,arr[0]); inserted = true; break;}}if(!inserted){insert(result,result.length,arr[0]);}arr.splice(0,1);}return result;}function insert(arr,i,v){arr.splice(i,0,v);}var input = new Array(5,1,4,2,3);var ret = insertSort(input,function(a,b){return a > b;});console.log(ret);var input = new Array(5,1,4,2,3);ret = insertSort(input,function(a,b){return a < b;});console.log(ret); |
//shell sort
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
function shellSort (a,comp) { for (var h = a.length; h = parseInt(h / 2);) { for (var i = h; i < a.length; i++) { var k = a[i]; for (var j = i; j >= h && comp(k, a[j - h]); j -= h) a[j] = a[j - h]; a[j] = k; } } return a;}var arr =new Array(7,9,2,5,4,1,3);var r = shellSort(arr,function (a,b){return a > b;});console.log(r); |
//merge sort
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
|
function mergeS(arr,comp){if(arr.length == 1){return arr;}var mid = arr.length / 2 | 0;var leftArr = new Array();var rightArr = new Array();for(var i = 0;i < mid;i ++){leftArr.push(arr[i]);}for(var j = mid;j < arr.length; j++){rightArr.push(arr[j]);}console.log("before : " + leftArr + " | " + rightArr);var leftRet = mergeS(leftArr,comp);var rightRet = mergeS(rightArr,comp);var r = merge(leftRet,rightRet,comp);return r;}function merge(leftArr,rightArr,comp){var ret = new Array();var i = j = 0;for(;i < leftArr.length && j < rightArr.length; ){if(comp(leftArr[i],rightArr[j])){ret.push(leftArr[i]); i ++}else {ret.push(rightArr[j]); j ++}}for(;i < leftArr.length;){ret.push(leftArr[i]);i++;}for(;j< rightArr.length; ){ret.push(rightArr[j]);j++;}return ret;}var r = mergeS(new Array(0,6,5,1,2,4,3,9),function(a,b){return a > b;});console.log(r); |
//quick sort
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
|
function quickS(arr,lo,hi,comp){if(lo >= hi){return ;}var stub = arr[lo];var i = lo + 1;var j = hi;for(;i < j ;){for(;i < j && !comp(stub,arr[j]);j--);for(;i < j && comp(stub,arr[i]);i++);if(i >= j){break;}var t = arr[i];arr[i] = arr[j];arr[j] = t;j--;i++;}if(comp(arr[lo],arr[i])){var t = arr[lo];arr[lo] = arr[i];arr[i] = t;}quickS(arr,lo,i-1,comp);quickS(arr,i,hi,comp);}var input = new Array(22,3,10,66,15,11,2,4,31,9);quickS(input, 0, input.length - 1,function(a,b){return a > b;});console.log(input); |
//heap sort
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
var ret = new Array();function heapS(arr,comp){if(arr.length == 0){return ;}var i = arr.length / 2 | 0 ;for(;i >= 0; i--){if(comp(arr[i], arr[i * 2])){exch(arr, i, i*2);}if(comp(arr[i], arr[i * 2 + 1])) {exch(arr, i, i*2 + 1);}}ret.push(arr[0]);arr.splice(0,1);heapS(arr,comp);}function exch(arr,i,j){var t = arr[i];arr[i] = arr[j];arr[j] = t;}heapS(new Array(16,22,91,0,51,44,23),function (a,b){return a > b;});console.log(ret);
|
8大排序算法总结 JS 实现的更多相关文章
- [ 转载 ] js十大排序算法:冒泡排序
js十大排序算法:冒泡排序 http://www.cnblogs.com/beli/p/6297741.html
- 使用 js 实现十大排序算法: 快速排序
使用 js 实现十大排序算法: 快速排序 QuickSort 快速排序 /** * * @author xgqfrms * @license MIT * @copyright xgqfrms * @c ...
- 使用 js 实现十大排序算法: 桶排序
使用 js 实现十大排序算法: 桶排序 桶排序 refs xgqfrms 2012-2020 www.cnblogs.com 发布文章使用:只允许注册用户才可以访问!
- 使用 js 实现十大排序算法: 计数排序
使用 js 实现十大排序算法: 计数排序 计数排序 refs xgqfrms 2012-2020 www.cnblogs.com 发布文章使用:只允许注册用户才可以访问!
- 使用 js 实现十大排序算法: 基数排序
使用 js 实现十大排序算法: 基数排序 基数排序 refs xgqfrms 2012-2020 www.cnblogs.com 发布文章使用:只允许注册用户才可以访问!
- 使用 js 实现十大排序算法: 冒泡排序
使用 js 实现十大排序算法: 冒泡排序 冒泡排序 refs xgqfrms 2012-2020 www.cnblogs.com 发布文章使用:只允许注册用户才可以访问!
- 使用 js 实现十大排序算法: 希尔排序
使用 js 实现十大排序算法: 希尔排序 希尔排序 refs xgqfrms 2012-2020 www.cnblogs.com 发布文章使用:只允许注册用户才可以访问!
- 使用 js 实现十大排序算法: 插入排序
使用 js 实现十大排序算法: 插入排序 插入排序 // 双重循环 refs xgqfrms 2012-2020 www.cnblogs.com 发布文章使用:只允许注册用户才可以访问!
- 使用 js 实现十大排序算法: 选择排序
使用 js 实现十大排序算法: 选择排序 选择排序 refs xgqfrms 2012-2020 www.cnblogs.com 发布文章使用:只允许注册用户才可以访问!
随机推荐
- mybatis自己学习的一些总结
曾经一直在使用spring的JDBCTEMPLATE和hibernate做项目.两个都还不错,spring的jdbctemplate用起来比較麻烦,尽管非常easy.而hibernate呢,用起来非常 ...
- struts2(五) s标签和国际化
坚持就是胜利. --WH 一.s标签 在struts-2.3.15.1/docs/WW/docs/tag-reference.html下,就有着struts2所有标签的参考文献,只能看看其中比较常用的 ...
- [svc]mount命令及解决因/etc/fstab错误导致系统不能启动故障
mount命令-手动挂载设备 格式: mount [options] [-t fstype] [-o option] 设备 挂载点 mount -n -o remount,rw / - Mount t ...
- CodeSign error: code signing is required for product type Application in SDK iOS XXX的解决办法
转自:http://www.tuicool.com/articles/jYRNbm 在真机测试的时候往往会突然出现这样一个错误,code signing is required for product ...
- 菜鸟学SSH(十七)——基于注解的SSH将配置精简到极致
很早之前就想写一篇关于SSH整合的博客了,但是一直觉得使用SSH的时候那么多的配置文件,严重破坏了我们代码整体性,比如你要看两个实体的关系还得对照*.hbm.xml文件,要屡清一个Action可能需要 ...
- python TCP编程
1.socket 服务端和客户端通过socket套接字进行通信 2.服务端 import socket import threading def tcp_handler(connect_sock, a ...
- Implementation Notes: Runtime Environment Map Filtering for Image Based Lighting
https://placeholderart.wordpress.com/2015/07/28/implementation-notes-runtime-environment-map-filteri ...
- Android,XML解析
XML解析三种方式 DOM 通用性强,它会将XML文件的所有内容读取到内存中,然后允许您使用DOM API遍历XML树.检索所需的数据: 简单直观,但需要将文档读取到内存,并不太适合移动设备: SAX ...
- Linux环境系搭建Git服务器过程全纪录
Last :: from 139.199.180.186 [root@VM_219_131_centos ~]# yum install curl-devel expat-devel gettext- ...
- Linux中查看GNOME版本号
在使用图形终端时,可以在虚拟终端中直接输入gnome-about,会弹出如下窗口. 或者在纯命令行模式下使用下面命令: $ gnome-about --gnome-version 注:Gnome 3. ...