JavaScript實現兩個數組取交集

一、js兩個數組取交集的差級

在JavaScript中,可以使用Set對象實現兩個數組的差集。Set是一種特殊的數據結構,它是一組獨特且不重複的值的集合。

const set1 = new Set([1, 2, 3, 4, 5]);
const set2 = new Set([4, 5, 6, 7, 8]);
const difference = new Set(Array.from(set1).filter(x => !set2.has(x)));
console.log(difference); // Set {1, 2, 3}

這裡通過Set對象來存儲兩個數組的值,然後根據判斷條件,得到差級。這裡使用了Array.from()方法將Set對象轉換為數組,使用filter()方法過濾出符合條件的結果。

二、js兩個數組取交集演算法

JavaScript中,還可以使用更簡單的方法來實現兩個數組的交集。對於數組1進行遍歷,比較數組2中的每個元素,如果找到相等的則加入到結果數組中。不過需要注意的是,在對於數組的遍歷過程中,需要使用indexOf()函數來進行判斷該元素是否存在於數組2中。

const arr1 = [1, 2, 3, 4, 5];
const arr2 = [4, 5, 6, 7, 8];
const intersection = [];
for (let i = 0; i < arr1.length; i++) {
  if (arr2.indexOf(arr1[i]) !== -1) {
    intersection.push(arr1[i]);
  }
}
console.log(intersection); // [4, 5]

上述方法的時間複雜度為O(n^2),如果兩個數組的長度特別大,那麼執行效率可能會非常低。為了避免這種情況,可以使用更高效的演算法。

三、js兩個數組的交集

對於兩個數組的交集問題,可以採用哈希表(HashMap)來實現。將其中一個數組的元素存儲在哈希表中,然後遍歷另一個數組,判斷該數組的元素是否在哈希表中存在。

function intersection(arr1, arr2) {
  const map = new Map();
  const result = [];
  for (let i = 0; i < arr1.length; i++) {
    map.set(arr1[i], true);
  }
  for (let j = 0; j < arr2.length; j++) {
    if (map.get(arr2[j])) {
      result.push(arr2[j]);
    }
  }
  return result;
}
console.log(intersection([1, 2, 3, 4, 5], [4, 5, 6, 7, 8])); // [4, 5]

使用Map對象將數組1中的元素存入,然後判斷數組2中的元素是否在Map中出現過,並將其加入到結果數組中。

四、js兩個數組取差集

除了求交集,還有一個常用的問題就是求差級。可以使用數組中的filter()方法來實現。

function difference(arr1, arr2) {
  return arr1.filter(x => !arr2.includes(x));
}
console.log(difference([1, 2, 3, 4, 5], [4, 5, 6, 7, 8])); // [1, 2, 3]

該方法中,使用filter()方法過濾掉數組1中在數組2中出現過的元素。

五、計算兩個數組的交集

以上介紹的演算法都是基於無序數組計算交集的。對於有序數組,可以採用更高效的方法來計算交集。這裡可以使用雙指針技巧。

function intersection(arr1, arr2) {
  const result = [];
  let i = 0, j = 0;
  while (i < arr1.length && j < arr2.length) {
    if (arr1[i] < arr2[j]) {
      i++;
    } else if (arr1[i] > arr2[j]) {
      j++;
    } else {
      result.push(arr1[i]);
      i++;
      j++;
    }
  }
  return result;
}
console.log(intersection([1, 2, 3, 4, 5], [4, 5, 6, 7, 8])); // [4, 5]

該方法使用了i和j兩個指針,分別指向數組1和數組2中的當前元素。如果當前元素相等,則將其加入到結果數組中,否則將指針偏移。

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/239391.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-12 12:16
下一篇 2024-12-12 12:16

相關推薦

  • 利用Python實現兩個鏈表合併為一個有序鏈表

    對於開發工程師來說,實現兩個鏈表合併為一個有序鏈表是必須掌握的技能之一。Python語言在鏈表處理上非常便利,本文將從多個方面詳細闡述如何利用Python實現兩個鏈表合併為一個有序…

    編程 2025-04-29
  • Python導入數組

    本文將為您詳細闡述Python導入數組的方法、優勢、適用場景等方面,並附上代碼示例。 一、numpy庫的使用 numpy是Python中一個強大的數學庫,其中提供了非常豐富的數學函…

    編程 2025-04-29
  • Python返回數組:一次性搞定多種數據類型

    Python是一種多用途的高級編程語言,具有高效性和易讀性的特點,因此被廣泛應用於數據科學、機器學習、Web開發、遊戲開發等各個領域。其中,Python返回數組也是一項非常強大的功…

    編程 2025-04-29
  • Python去掉數組的中括弧

    在Python中,被中括弧包裹的數據結構是列表,列表是Python中非常常見的數據類型之一。但是,有些時候我們需要將列表展開成一維的數組,並且去掉中括弧。本文將為大家詳細介紹如何用…

    編程 2025-04-29
  • Python操作數組

    本文將從多個方面詳細介紹如何使用Python操作5個數組成的列表。 一、數組的定義 數組是一種用於存儲相同類型數據的數據結構。Python中的數組是通過列表來實現的,列表中可以存放…

    編程 2025-04-29
  • Python定義兩個列表的多面探索

    Python是一種強大的編程語言,開放源代碼,易於學習和使用。通過Python語言,我們可以定義各種數據類型,如列表(list)。在Python中,列表(list)在處理數據方面起…

    編程 2025-04-29
  • Python二維數組對齊輸出

    本文將從多個方面詳細闡述Python二維數組對齊輸出的方法與技巧。 一、格式化輸出 Python中提供了格式化輸出的方法,可以對輸出的字元串進行格式化處理。 names = [‘A…

    編程 2025-04-29
  • Python兩個線程交替列印1到100

    這篇文章的主題是關於Python多線程的應用。我們將會通過實際的代碼,學習如何使用Python兩個線程交替列印1到100。 一、創建線程 在Python中,我們可以使用Thread…

    編程 2025-04-28
  • Java創建一個有10萬個元素的數組

    本文將從以下方面對Java創建一個有10萬個元素的數組進行詳細闡述: 一、基本介紹 Java是一種面向對象的編程語言,其強大的數組功能可以支持創建大規模的多維數組以及各種複雜的數據…

    編程 2025-04-28
  • Python數組隨機分組用法介紹

    Python數組隨機分組是一個在數據分析與處理中常用的技術,它可以將一個大的數據集分成若干組,以便於進行處理和分析。本文將從多個方面對Python數組隨機分組進行詳細的闡述,包括使…

    編程 2025-04-28

發表回復

登錄後才能評論