Rumah >hujung hadapan web >tutorial js >Bagaimanakah Saya Boleh Mencari Persimpangan, Perbezaan dan Perbezaan Simetri Dua Tatasusunan JavaScript dengan Cekap?

Bagaimanakah Saya Boleh Mencari Persimpangan, Perbezaan dan Perbezaan Simetri Dua Tatasusunan JavaScript dengan Cekap?

Barbara Streisand
Barbara Streisandasal
2024-12-29 03:39:10832semak imbas

How Can I Efficiently Find the Intersection, Difference, and Symmetric Difference of Two JavaScript Arrays?

Mencari Perbezaan Tatasusunan dalam JavaScript: Persilangan, Perbezaan dan Perbezaan Simetri

Dalam JavaScript, membandingkan tatasusunan elemen demi elemen boleh membosankan . Untuk memudahkan proses ini, mari kita terokai alat yang berkuasa: Array.prototype.includes().

Persimpangan

Untuk mendapatkan nilai yang biasa kepada kedua-dua tatasusunan, kami boleh menggunakan penapis(). Contohnya:

let intersection = arr1.filter(x => arr2.includes(x));

Ini menghasilkan persimpangan: [2, 3].

Perbezaan

Untuk mengenal pasti nilai yang hadir hanya dalam arr1, kita boleh menapis unsur-unsur yang wujud dalam arr2.

let difference = arr1.filter(x => !arr2.includes(x));

Ini menghasilkan perbezaan: [1].

Perbezaan Simetri

Untuk mendapatkan elemen yang ditemui secara eksklusif sama ada dalam arr1 atau arr2, kami menggabungkan dua perbezaan:

let symDifference = arr1.filter(x => !arr2.includes(x))
                        .concat(arr2.filter(x => !arr1.includes(x)));

Ini menghasilkan perbezaan simetri: [1].

Seperti yang diserlahkan oleh @Joshaven Potter, kaedah ini boleh ditambah terus ke Array.prototype untuk fleksibiliti yang dipertingkatkan:

Array.prototype.diff = function(arr2) { 
  return this.filter(x => !arr2.includes(x)); 
}

Kemudian, anda boleh menggunakannya terus pada tatasusunan:

[1, 2, 3].diff([2, 3]) // [1]

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mencari Persimpangan, Perbezaan dan Perbezaan Simetri Dua Tatasusunan JavaScript dengan Cekap?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn