久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁技術文章
文章詳情頁

如何基于js及java分析并封裝排序算法

瀏覽:5日期:2022-08-28 13:38:00

前言

本次來分享一下排序的api底層的邏輯,這次用js模擬,java的邏輯也是差不多。

先看封裝好的api例子:

  js的sort排序

如何基于js及java分析并封裝排序算法

  java的compareTo排序

如何基于js及java分析并封裝排序算法

如何基于js及java分析并封裝排序算法

自己模擬的代碼(JS)

function compareTo(a,b){ return a-b;//a-b為從下到大 b-a為從大到小}Object.prototype.newSort = function(Func){ const flag = Func(1,0); const $this = this; // 注意:上面for循環的$this.length-1是因為這里只需要走到倒數第二個位置即可,而下面的for循環$this.length-1是數組下標對應的最后一個值 for(let i = 0; i < $this.length-1; i++){ for(let j = $this.length-1; j > i; j--){ // 思路就是從數組第一個開始與倒數第一個向上直到數組第二個的過程中一直比較,如果有比第一個小的,就交換,然后第二次循環就只需要第二個與倒數第二個開始比較,以此類推 const compare = flag > 0 ? $this[i] > $this[j] : $this[i] < $this[j]; if(compare){//滿足條件就進行位運算來交換位置 $this[i] = $this[i] ^ $this[j]; $this[j] = $this[i] ^ $this[j]; $this[i] = $this[i] ^ $this[j]; } } }}var array = [2,1,5,7,3,4,9,8,6,4,5,2,1];console.log(array.newSort(compareTo));//[ 1, 1, 2, 2, 3, 4, 4, 5, 5, 6, 7, 8, 9 ]

源代碼

js源代碼

如何基于js及java分析并封裝排序算法

java源代碼

如何基于js及java分析并封裝排序算法

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Java
相關文章:
主站蜘蛛池模板: 小金县| 休宁县| 乐都县| 西充县| 新闻| 康平县| 通河县| 孝义市| 青河县| 黑水县| 庆元县| 勐海县| 潮州市| 固阳县| 务川| 五河县| 北京市| 邻水| 内丘县| 南昌县| 杭锦后旗| 南部县| 六枝特区| 木兰县| 舟山市| 竹山县| 蕉岭县| 乌鲁木齐县| 井冈山市| 高州市| 江北区| 吉木萨尔县| 故城县| 饶阳县| 类乌齐县| 曲靖市| 义乌市| 元阳县| 宜州市| 嵊州市| 平遥县|