//集合取交集
Array.intersect = function () { var result = new Array(); var obj = {}; for (var i = 0; i < arguments.length; i++) { for (var j = 0; j < arguments[i].length; j++) { var str = arguments[i][j]; if (!obj[str]) { obj[str] = 1; } else { obj[str]++; if (obj[str] == arguments.length) { result.push(str); } }//end else }//end for j }//end for i return result; }
//集合去掉重復
Array.prototype.uniquelize = function () { var tmp = {}, ret = []; for (var i = 0, j = this.length; i < j; i++) { if (!tmp[this[i]]) { tmp[this[i]] = 1; ret.push(this[i]); } } return ret; }
//并集
Array.union = function () { var arr = new Array(); var obj = {}; for (var i = 0; i < arguments.length; i++) { for (var j = 0; j < arguments[i].length; j++) { var str=arguments[i][j]; if (!obj[str]) { obj[str] = 1; arr.push(str); } }//end for j }//end for i return arr; }
//2個集合的差集 在arr不存在
Array.prototype.minus = function (arr) { var result = new Array(); var obj = {}; for (var i = 0; i < arr.length; i++) { obj[arr[i]] = 1; } for (var j = 0; j < this.length; j++) { if (!obj[this[j]]) { obj[this[j]] = 1; result.push(this[j]); } } return result; };
console.log(Array.intersect(["1", "2", "3"], ["2", "3", "4", "5", "6"]));//[2,3] console.log([1, 2, 3, 2, 3, 4, 5, 6].uniquelize());//[1,2,3,4,5,6] console.log(Array.union(["1", "2", "3"], ["2", "3", "4", "5", "6"], ["5", "6", "7", "8", "9"])) console.log(["2", "3", "4", "5", "6"].minus(["1", "2", "3"]));
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/83546.html
摘要:前言總結了一下有關于數組的差集交集并集的方法的方法實現去重簡單的數組去重請傳入數組類型并集簡單數組的并集交集簡單數組的交集差集簡單數組的差集的方法實現去重簡單的數組去重請傳入數組類型交集簡單數組的交集請都傳入數組類型并集簡單數組的并集請都傳 前言 總結了一下有關于數組的差集、交集、并集的方法; es6的方法實現 去重 /** * 簡單的數組去重 * @param {Array} a...
摘要:同樣的,由于下面會用到的方法,低版本會存在兼容,先應添加對應的依賴數組去重方法數組去重交集交集元素由既屬于集合又屬于集合的元素組成使用方式并集并集元素由集合和集合中所有元素去重組成使用方式差集的差集屬于集合不屬于集合的元素的差集屬于集合 同樣的,由于下面會用到ES5的方法,低版本會存在兼容,先應添加對應的polyfill Array.prototype.indexOf = Array....
摘要:數組判斷是否含有某個元素數組去重交集差集并集數組數組交集是差集是并集是臨時寫,有問題可以交流,對于其他的余集補集合集懶得區分了上面三種挺常用的,僅供參考。 Document //數組判斷是否含有某個元素 Array.prototype.contains = function (obj) { ...
摘要:與條件判斷一般我們判斷或用如果我們有更多水果與去重提供了新的數據結構。所以所有的關于數據的操作,都可以用函數式的方式處理。這樣做的可讀性遠遠高于嵌套一大堆的函數調用我們選擇一些函數,讓它們結合,生成一個嶄新的函數。 1、Array.includes 與條件判斷 一般我們判斷或用 || // condition function test(fruit) { if (fruit...
摘要:此文章用于增強數組使用的靈活度,如有更好的方法,希望留言互相交流數組去重方法一方法二方法三方法四取數組中的最大值方法一方法二數組的交集并集差集并集交集差集 此文章用于增強數組api使用的靈活度,如有更好的方法,希望留言互相交流^_^ 1.數組去重方法一function duplicateRemoval1(arr) { arr.sort(); let tmp=arr[0]; for (v...
閱讀 2135·2021-10-14 09:43
閱讀 2197·2019-08-30 15:55
閱讀 726·2019-08-30 14:23
閱讀 2019·2019-08-30 13:21
閱讀 1235·2019-08-30 12:50
閱讀 2199·2019-08-29 18:46
閱讀 2280·2019-08-29 17:28
閱讀 2359·2019-08-29 17:21