


5 pelaksanaan algoritma untuk kemahiran deduplication_javascript tatasusunan js
1. Kaedah traversal tatasusunan
Kaedah penyahduplikasian yang paling mudah, idea pelaksanaan: Cipta tatasusunan baharu, lalui tatasusunan masuk dan tambah nilai jika tiada dalam tatasusunan baharu Nota: Tentukan sama ada nilai itu adalah dalam Kaedah tatasusunan "indexOf" ialah kaedah ECMAScript5, yang tidak disokong oleh IE8 dan di bawah Anda perlu menulis lebih banyak kod agar serasi dengan pelayar versi yang lebih rendah adalah seperti berikut:
// 最简单数组去重法 function unique1(array){ var n = []; //一个新的临时数组 //遍历当前数组 for(var i = 0; i < array.length; i++){ //如果当前数组的第i已经保存进了临时数组,那么跳过, //否则把当前项push到临时数组里面 if (n.indexOf(array[i]) == -1) n.push(array[i]); } return n; }
2. Kaedah pasangan nilai kunci objek
Kaedah ini dilaksanakan lebih pantas daripada kaedah lain, tetapi ia menggunakan lebih banyak memori Idea pelaksanaan: Cipta objek js baharu dan tatasusunan baharu, dan apabila melintasi tatasusunan yang masuk, nilaikan. nilai Adakah ia kunci objek js Jika tidak, tambahkan kunci pada objek dan masukkan ke dalam tatasusunan baharu. Nota: Apabila menentukan sama ada ia adalah kunci objek js, "toString()" akan dilaksanakan secara automatik pada kunci masuk yang berbeza mungkin disalah anggap sama sebagai contoh: a[1], a["1"]. Untuk menyelesaikan masalah di atas, anda masih perlu memanggil "indexOf".
// 速度最快, 占空间最多(空间换时间) function unique2(array){ var n = {}, r = [], len = array.length, val, type; for (var i = 0; i < array.length; i++) { val = array[i]; type = typeof val; if (!n[val]) { n[val] = [type]; r.push(val); } else if (n[val].indexOf(type) < 0) { n[val].push(type); r.push(val); } } return r; }
3. Kaedah penghakiman subskrip tatasusunan
Anda masih perlu memanggil "indexOf" dan prestasi adalah serupa dengan kaedah 1. Idea pelaksanaan: Jika item ke-i tatasusunan semasa mula-mula muncul pada kedudukan selain daripada i dalam tatasusunan semasa, maka ia bermakna item ke-i Item i diulang dan diabaikan. Jika tidak, simpan tatasusunan hasil.
function unique3(array){ var n = [array[0]]; //结果数组 //从第二项开始遍历 for(var i = 1; i < array.length; i++) { //如果当前数组的第i项在当前数组中第一次出现的位置不是i, //那么表示第i项是重复的,忽略掉。否则存入结果数组 if (array.indexOf(array[i]) == i) n.push(array[i]); } return n; }
4. Kaedah penyingkiran bersebelahan selepas mengisih
Walaupun hasil pengisihan kaedah "isih" tatasusunan asli tidak begitu boleh dipercayai, kelemahan ini tidak mempunyai kesan dalam penduadua yang tidak memberi perhatian kepada pesanan. Idea pelaksanaan: Isih tatasusunan yang masuk Selepas mengisih, nilai yang sama bersebelahan, dan kemudian apabila melintasi, hanya tambah nilai yang bukan pendua nilai sebelumnya kepada. tatasusunan baharu.
// 将相同的值相邻,然后遍历去除重复值 function unique4(array){ array.sort(); var re=[array[0]]; for(var i = 1; i < array.length; i++){ if( array[i] !== re[re.length-1]){ re.push(array[i]); } } return re; }
5. Optimumkan kaedah traversal tatasusunan
Kod pelaksanaan kaedah ini agak hebat, Idea pelaksanaan: Dapatkan nilai paling tepat tanpa pendua dan masukkannya ke dalam tatasusunan baharu. (Apabila nilai pendua dikesan, gelung semasa ditamatkan dan pusingan penghakiman seterusnya bagi gelung peringkat atas dimasukkan) Disyorkan
// 思路:获取没重复的最右一值放入新数组 function unique5(array){ var r = []; for(var i = 0, l = array.length; i < l; i++) { for(var j = i + 1; j < l; j++) if (array[i] === array[j]) j = ++i; r.push(array[i]); } return r; }
Tentukan sama ada penyemak imbas menyokong indexOf ialah kaedah baharu ecmaScript5 Ia tidak disokong oleh IE8 dan ke bawah (termasuk IE8, IE8 hanya menyokong sebahagian daripada ecma5)
if (!Array.prototype.indexOf){ // 新增indexOf方法 Array.prototype.indexOf = function(item){ var result = -1, a_item = null; if (this.length == 0){ return result; } for(var i = 0, len = this.length; i < len; i++){ a_item = this[i]; if (a_item === item){ result = i; break; } } return result; } }
Di atas ialah 5 pelaksanaan algoritma penyahduplikasi tatasusunan JS yang disediakan untuk anda.

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



Soalan dan penyelesaian yang sering ditanya untuk percetakan tiket kertas terma depan dalam pembangunan front-end, percetakan tiket adalah keperluan umum. Walau bagaimanapun, banyak pemaju sedang melaksanakan ...

Tidak ada gaji mutlak untuk pemaju Python dan JavaScript, bergantung kepada kemahiran dan keperluan industri. 1. Python boleh dibayar lebih banyak dalam sains data dan pembelajaran mesin. 2. JavaScript mempunyai permintaan yang besar dalam perkembangan depan dan stack penuh, dan gajinya juga cukup besar. 3. Faktor mempengaruhi termasuk pengalaman, lokasi geografi, saiz syarikat dan kemahiran khusus.

JavaScript adalah asas kepada pembangunan web moden, dan fungsi utamanya termasuk pengaturcaraan yang didorong oleh peristiwa, penjanaan kandungan dinamik dan pengaturcaraan tak segerak. 1) Pengaturcaraan yang didorong oleh peristiwa membolehkan laman web berubah secara dinamik mengikut operasi pengguna. 2) Penjanaan kandungan dinamik membolehkan kandungan halaman diselaraskan mengikut syarat. 3) Pengaturcaraan Asynchronous memastikan bahawa antara muka pengguna tidak disekat. JavaScript digunakan secara meluas dalam interaksi web, aplikasi satu halaman dan pembangunan sisi pelayan, sangat meningkatkan fleksibiliti pengalaman pengguna dan pembangunan silang platform.

Bagaimana cara menggabungkan elemen array dengan ID yang sama ke dalam satu objek dalam JavaScript? Semasa memproses data, kita sering menghadapi keperluan untuk mempunyai id yang sama ...

Perbincangan mengenai realisasi kesan animasi tatal dan elemen Parallax dalam artikel ini akan meneroka bagaimana untuk mencapai yang serupa dengan laman web rasmi Shiseido (https://www.shiseido.co.jp/sb/wonderland/) ... ...

Perbincangan mendalam mengenai punca-punca utama perbezaan dalam output konsol.log. Artikel ini akan menganalisis perbezaan hasil output fungsi Console.log dalam sekeping kod dan menerangkan sebab -sebab di belakangnya. � ...

Pembelajaran JavaScript tidak sukar, tetapi ia mencabar. 1) Memahami konsep asas seperti pembolehubah, jenis data, fungsi, dan sebagainya. 2) Pengaturcaraan asynchronous tuan dan melaksanakannya melalui gelung acara. 3) Gunakan operasi DOM dan berjanji untuk mengendalikan permintaan tak segerak. 4) Elakkan kesilapan biasa dan gunakan teknik debugging. 5) Mengoptimumkan prestasi dan mengikuti amalan terbaik.

Terokai pelaksanaan fungsi seretan panel dan drop panel seperti VSCode di bahagian depan. Dalam pembangunan front-end, bagaimana untuk melaksanakan vscode seperti ...
