JS求多個數(shù)組的重復數(shù)據(jù)
今天朋友問了我這個問題:JS求多個數(shù)組的重復數(shù)據(jù)
注:
1.更準確的說是只要多個數(shù)組中有兩個以上的重復數(shù)據(jù),那么這個數(shù)據(jù)就是我需要的
2.單個數(shù)組內(nèi)的數(shù)據(jù)不存在重復值(當然如果有的話,你可以去重)
3.耗時問題,這一點很重要
源代碼:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>獲取多個數(shù)組中的重復數(shù)據(jù)</title>
</head>
<body>
<script type="text/javascript">
//計算用時
function useTime(date1,date2){
var date3=date2.getTime()-date1.getTime() //時間差的毫秒數(shù)
//計算出相差天數(shù)
var days=Math.floor(date3/(24*3600*1000))
//計算出小時數(shù)
var leave1=date3%(24*3600*1000) //計算天數(shù)后剩余的毫秒數(shù)
var hours=Math.floor(leave1/(3600*1000))
//計算相差分鐘數(shù)
var leave2=leave1%(3600*1000) //計算小時數(shù)后剩余的毫秒數(shù)
var minutes=Math.floor(leave2/(60*1000))
//計算相差秒數(shù)
var leave3=leave2%(60*1000) //計算分鐘數(shù)后剩余的毫秒數(shù)
var seconds=Math.round(leave3/1000)
return "用時:"+days+" "+hours+":"+minutes+":"+seconds+" "+leave3%1000;//+"''";
}
//返回min,max之間的數(shù)組成的數(shù)據(jù),長度為max-min+1(數(shù)據(jù)是固定的,只是順序隨機)
function getArr(min,max){
var arr = [];
var numToPush = min;
for (var i = 0; i < max-min+1; i++) {
var len = arr.length;
if (len==0) {
arr.push(numToPush++);
}else{
var randIndex = Math.floor(Math.random()*len);
arr.push(numToPush++);
//arr中的某一位跟最后一位交換
var tmp = arr[randIndex];
arr[randIndex] = arr[len];
arr[len] = tmp;
}
}
return arr;
}
//返回min,max之間的數(shù)組成的數(shù)據(jù),個數(shù)為num(數(shù)據(jù)隨機)
function randomArr(min,max,num){
var arr = [];
for (var i = 0; i < num; i++) {
var randomNumber = Math.floor(Math.random()*(max-min)+min);
var inArr = false;
for (var i = 0; i < arr.length; i++) {
if(arr[i]==randomNumber){
inArr = true;
num--;
break;
}
}
if (!inArr) {
arr.push(randomNumber);
}
}
return arr;
}
//獲取重復的數(shù)據(jù)
function getDumplicate(){
var num = arguments.length;
if (num<2) { return [];};
var obj = {
ret:[], //存儲相同的數(shù)據(jù)
container:[] //存儲不同的數(shù)據(jù)
}
for (var i = 0; i < 3; i++) {
// console.log(arguments[i]);
var arr = arguments[i];
obj = deal(arr,obj);
}
return obj;
}
//處理單個數(shù)組,跟容器中的數(shù)據(jù)比較,并獲得重復數(shù)據(jù)(問題:數(shù)據(jù)量太大會造成容器中的數(shù)據(jù)過多)
function deal(arr,obj){
var len = obj.container.length;
if(len==0) {
obj.container = arr;
}else{
var arrlen = arr.length;
for (var j = 0; j < arrlen; j++) {//遍歷數(shù)組,每個元素都跟container比較
var conlen = obj.container.length;
var intoContainer = false;
for (var i = 0; i < conlen; i++) {
var conValue = obj.container[i];
if(arr[j]==conValue){ //重復的放入ret
obj.ret.push(arr[j]);
intoContainer = true;
}
}
if(intoContainer&&!inArr(arr[j],obj.container)){
obj.container.push(arr[j]); //不重復的放入容器
}
}
}
return obj;
}
//檢測數(shù)組中是否已經(jīng)存在這個數(shù)據(jù)
function inArr(obj,arr){
var exist = false;
var len = arr.length;
for (var i = 0; i < len; i++) {
if (arr[i]==obj) {
exist = true;
}
}
return exist;
}
//-------------------------測試--------------------------------------------
var date = new Date();
var arr_a = getArr(1,20);
var arr_b = getArr(18,35);
var arr_c = getArr(34,50);
var dumpData= getDumplicate(arr_a,arr_b,arr_c);
console.log(dumpData.ret);
//console.log(dumpData.container);
console.log(useTime(date,new Date()));
console.log("-----------------數(shù)據(jù)更加隨機-----------------------");
var date1 = new Date();
// console.log(randomArr(1,100,10));
console.log(getDumplicate( randomArr(1,1000000,10000),
randomArr(1,1000000,10000),
randomArr(1,1000000,10000),
randomArr(1,1000000,10000),
randomArr(1,1000000,10000)
).ret)
var useTime = useTime(date1,new Date());
console.log(useTime);
</script>
</body>
</html>
結(jié)果:

我們測試更多數(shù)據(jù):隨機產(chǎn)生3個數(shù)組,共計3W條數(shù)據(jù)
結(jié)果:

5個數(shù)組5W數(shù)據(jù):(數(shù)據(jù)分布:1W/數(shù)組)

5個數(shù)組10W數(shù)據(jù):(數(shù)據(jù)分布:5W,4W,3W,2W,1W)

10個數(shù)組10W數(shù)據(jù):(數(shù)據(jù)分布:1W/數(shù)組)

100個數(shù)組100W數(shù)據(jù):(數(shù)據(jù)分布:1W/數(shù)組)

結(jié)論:
1.耗時的多少取決于你的算法
2.總數(shù)據(jù)不變的情況下:數(shù)組個數(shù)盡量多,單個數(shù)組的數(shù)據(jù)不能太多.當然不能一概而論
3.本測試中,單個數(shù)組1W數(shù)據(jù)還行,5W數(shù)據(jù)不死,10W數(shù)據(jù)請找華佗
問題:
1.算法是臨時寫的(其實沒什么算法^_^),有待改進
2.測試代碼中使用了一個數(shù)組容器,用于存儲不重復的數(shù)據(jù).
那么問題來了:數(shù)據(jù)量太大會造成容器中的數(shù)據(jù)過多,然后..你懂的.
3.測試數(shù)據(jù)是隨機生成的,并且只有數(shù)字.如果是其他對象,請另行測試(主要是測試數(shù)據(jù)不好生成(⊙o⊙)…)
4.多維數(shù)組未測試(測試性能也不一定好0_0)
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
- 分享JS數(shù)組求和與求最大值的方法
- JavaScript學習筆記之數(shù)組求和方法
- Javascript計算二維數(shù)組重復值示例代碼
- 計算100000數(shù)組js腳本的執(zhí)行時間
- 求js數(shù)組的最大值和最小值的四種方法
- javascript中數(shù)組中求最大值示例代碼
- JavaScript求一個數(shù)組中重復出現(xiàn)次數(shù)最多的元素及其下標位置示例
- JS求Number類型數(shù)組中最大元素方法
- js求數(shù)組中全部數(shù)字可拼接出的最大整數(shù)示例代碼
- JS實現(xiàn)求數(shù)組起始項到終止項之和的方法【基于數(shù)組擴展函數(shù)】
- JavaScript實現(xiàn)數(shù)組全排列、去重及求最大值算法示例
- JS數(shù)組求和的常用方法實例小結(jié)
相關(guān)文章
Java遞歸調(diào)用如何實現(xiàn)數(shù)字的逆序輸出方式
這篇文章主要介紹了Java遞歸調(diào)用如何實現(xiàn)數(shù)字的逆序輸出方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-04-04
Java原生服務器接收上傳文件 不使用MultipartFile類
這篇文章主要為大家詳細介紹了Java原生服務器接收上傳文件,不使用MultipartFile類,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-09-09
詳解eclipse將項目打包成jar文件的兩種方法及問題解決方法
本文給大家介紹了eclipse中將項目打包成jar文件的兩種方法及其遇到問題解決方法,本文圖文并茂給大家介紹的非常詳細,需要的朋友可以參考下2017-12-12
JavaFX 監(jiān)聽窗口關(guān)閉事件實例詳解
這篇文章主要介紹了JavaFX 監(jiān)聽窗口關(guān)閉事件實例詳解的相關(guān)資料,需要的朋友可以參考下2017-05-05
淺析Java?NIO?直接緩沖區(qū)和非直接緩沖區(qū)
本篇文章主要為大家介紹了Java?NIO?中直接緩沖區(qū)和非直接緩沖區(qū)的定義以及使用流程,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-11-11
java Spring MVC4環(huán)境搭建實例詳解(步驟)
spring WEB MVC框架提供了一個MVC(model-view-controller)模型-視圖-控制器的結(jié)構(gòu)和組件,利用它可以開發(fā)更靈活、松耦合的web應用。MVC模式使得整個服務應用的各部分(控制邏輯、業(yè)務邏輯、UI界面展示)分離開來,使它們之間的耦合性更低2017-08-08

