摘要:原文譯文排序算法的實現譯者冒泡排序插入排序選擇排序歸并排序快速排序譯文出處
原文:Sorting Algorithms in Javascript
譯文:排序算法的JavaScript實現
譯者:dwqs
冒泡排序let compare = (n1, n2) => n1 - n2; let bubbleSort = (arr, cmp = compare) => { for (let i = 0; i < arr.length; i++) { for (let j = i; j > 0; j--) { if (cmp(arr[j], arr[j - 1]) < 0) { [arr[j], arr[j - 1]] = [arr[j - 1], arr[j]]; } } } return arr; };插入排序
let insertionSort = (arr) => { for (let i = 0; i < a.length; i++) { let toCmp = arr[i]; for (let j = i; j > 0 && toCmp < a[j - 1]; j--) arr[j] = a[j - 1]; arr[j] = toCmp; } return arr; }選擇排序
var selectionSort = function (arr) { let i,m,j; for (i = -1; ++i < a.length;) { for (m = j = i; ++j < a.length;) { if (arr[m] > arr[j]) m = j; } [arr[m], arr[i]] = [arr[i], arr[m]]; } return arr; }歸并排序
let mergeSort = (arr) => { if (arr.length < 2) return arr; let middle = parseInt(arr.length / 2), left = arr.slice(0, middle), right = arr.slice(middle); return merge(mergeSort(left), mergeSort(right)); } let merge = (left, right) => { let result = []; while (left.length && right.length) { left[0] <= right[0] ? result.push(left.shift()) : result.push(right.shift()); } while (left.length) result.push(left.shift()); while (right.length) result.push(right.shift()); return result; }快速排序
let quicksort = function(arr) { if(arr.length <= 1) return arr; let pivot = Math.floor((arr.length -1)/2); let val = arr[pivot], less = [], more = []; arr.splice(pivot, 1); arr.forEach(function(e,i,a){ e < val ? less.push(e) : more.push(e); }); return (quicksort(less)).concat([val],quicksort(more)) }
譯文出處:http://www.ido321.com/1492.html
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/85594.html
這里用JavaScript實現冒泡排序、選擇排序、插入排序、歸并排序以及快速排序這些常見的排序算法 首先我們給本文約定一個實現的框架:定義一個ArrayList類里面包含排序數組聲明、數組元素添加、排序算法實現以及數組輸出的方法。 代碼框架: function ArrayList(){ var array=[]; this.inputArrayme...
摘要:棧被稱為一種后入先出的數據結構。散列使用的數據結構叫做散列表。這些操作需要求助于其他數據結構,比如下面介紹的二叉查找樹。 前言 在過去的幾年中,得益于Node.js的興起,JavaScript越來越廣泛地用于服務器端編程。鑒于JavaScript語言已經走出了瀏覽器,程序員發現他們需要更多傳統語言(比如C++和Java)提供的工具。這些工具包括傳統的數據結構(如鏈表,棧,隊列,圖等),...
摘要:常見的內部排序算法有插入排序希爾排序選擇排序冒泡排序歸并排序快速排序堆排序基數排序等。用一張圖概括歸并排序英語,或,是創建在歸并操作上的一種有效的排序算法,效率為。 常見的內部排序算法有:插入排序、希爾排序、選擇排序、冒泡排序、歸并排序、快速排序、堆排序、基數排序等。用一張圖概括: showImg(https://segmentfault.com/img/bVNwuO?w=966&h=...
摘要:常見的內部排序算法有插入排序希爾排序選擇排序冒泡排序歸并排序快速排序堆排序基數排序等。用一張圖概括歸并排序英語,或,是創建在歸并操作上的一種有效的排序算法,效率為。 常見的內部排序算法有:插入排序、希爾排序、選擇排序、冒泡排序、歸并排序、快速排序、堆排序、基數排序等。用一張圖概括: showImg(https://segmentfault.com/img/bVNwuO?w=966&h=...
摘要:常見的內部排序算法有插入排序希爾排序選擇排序冒泡排序歸并排序快速排序堆排序基數排序等。用一張圖概括歸并排序英語,或,是創建在歸并操作上的一種有效的排序算法,效率為。 常見的內部排序算法有:插入排序、希爾排序、選擇排序、冒泡排序、歸并排序、快速排序、堆排序、基數排序等。用一張圖概括: showImg(https://segmentfault.com/img/bVNwuO?w=966&h=...
閱讀 2902·2021-11-23 09:51
閱讀 1547·2021-11-15 11:36
閱讀 3006·2021-10-13 09:40
閱讀 1864·2021-09-28 09:35
閱讀 13040·2021-09-22 15:00
閱讀 1367·2019-08-29 13:56
閱讀 2924·2019-08-29 13:04
閱讀 2699·2019-08-28 18:06