js三种排序算法分享_javascript技巧
May 16, 2016 pm 05:50 PM/**
* 值交换操作
* arr 被操作的数组
* i 被操作元素索引值
* j 被操作两元素的距离
*/
function refer(arr, i, j){
var change = (arr[i] - arr[i - j]) if (change) {
value = arr[i];
arr[i] = arr[i - j];
arr[i - j] = value;
return arguments.callee(arr, i - j, j);
}
else {
return arr;
}
}
//插入排序
function insert(array){
for (var i = 1, len = array.length; i if (array[i] refer(array, i, 1);
}
}
return array;
}
上面的部分是插入排序,然后是希尔排序:
//希尔排序
function shell(array){
var length = array.length, value;
for (var i = Math.floor(length / 2); i > 0; i = Math.floor(i / 2)) {
for (var j = i; j if (array[j] refer(array, j, i);
}
else {
continue;
}
}
}
return array;
}
两种方法当中用到的refer方法为同一个方法。最后是归并排序:
//归并排序
function order(arr1, arr2){
var arrLong = arr1.length > arr2.length ? arr1 : arr2;
var arrShort = arr1.length var arr = [];
for (var i = 0, l = arrShort.length; i for (var j = 0, len = arrLong.length; j if (arrShort[i] arr.push(arrShort[i]);
if (i == l - 1) {
for (var m = 0, n = arrLong.length; m arr[arr.length] = arrLong[m];
}
}
break;
}
else {
arr.push(arrLong[j]);
arrLong.shift();
continue;
}
}
}
return arr;
}
有好建议的同学可以留言!在此不多余赘述了,一切看代码吧。

Article chaud

Outils chauds Tags

Article chaud

Tags d'article chaud

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Problèmes complexes de conception expérimentale sur le marché biface de Kuaishou

Google utilise l'IA pour briser le sceau de dix ans de l'algorithme de tri. Elle est exécutée des milliards de fois chaque jour, mais les internautes disent que c'est la recherche la plus irréaliste ?

Comment filtrer et trier les données dans le développement de la technologie Vue

Quels sont les algorithmes de tri des tableaux ?

Swoole Advanced : Comment utiliser le multithreading pour implémenter un algorithme de tri à grande vitesse

Comment implémenter l'algorithme de tri par sélection en C#

Comment implémenter une fonction d'algorithme de tri simple à l'aide de MySQL et Java

Dix principaux algorithmes de tri que les programmeurs doivent maîtriser (Partie 1)
