码迷,mamicode.com
首页 > 编程语言 > 详细

javascript实现插入排序(直接插入排序和希尔排序)

时间:2017-05-01 09:47:09      阅读:201      评论:0      收藏:0      [点我收藏+]

标签:rtm   []   cti   first   pre   取数   math   create   creat   

/**
* Created by kaer on 2017/4/30.
*/

//直接插入排序:取数组第一个作为基准值,其它值以它为基准顺序插入
function straight (a){
var newArr = [];
var first = a[0];
var len = a.length;
newArr.push(first);
for(var i = 1;i<len;i++){
var newLen = newArr.length;
var b = true;
for(var j = 0;j<newLen;j++){
if(newArr[j]>a[i]){
newArr.splice(j,0,a[i]);
b = false;
break;
}
}
if(b){
newArr.push(a[i]);
}
}
return newArr;
}

//console.log(straight([5,2,6,3,4,1,0]));
//希尔排序:直接插入排序的改进版,以len/2,len/4,len/8....1,为间隔从原数组中取值,分别应用直接排序
function shellSort(a){
var len = a.length;
for(var n=Math.floor(len/2);n>=1;n=Math.floor(n/2)){
for(var i=0;(i+n)<len;i++){
var arrTmp = [];
var iTmp = [];
var sortArr = [];
for(var k=i,j=0;k<len;j++,k=i+j*n){
arrTmp.push(a[k]);
// console.log(arrTmp);
iTmp.push(k);
}
sortArr = straight(arrTmp);
for(var m =0;m<sortArr.length;m++){
a[iTmp[m]] = sortArr[m];
}
}
}
console.log(a);
}

shellSort([5,2,6,3,4,1,0]);

javascript实现插入排序(直接插入排序和希尔排序)

标签:rtm   []   cti   first   pre   取数   math   create   creat   

原文地址:http://www.cnblogs.com/kaer-blogs/p/6790933.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!