Dieses Mal werde ich Ihnen die Deduplizierung numerischer JS-Arrays vorstellen. Was sind die Vorsichtsmaßnahmen für die Deduplizierung numerischer JS-Arrays? Hier ist ein praktischer Fall.
Vorwort
In diesem Artikel werden hauptsächlich die relevanten Inhalte zum Erstellen eines Binärbaums mit js zur Deduplizierung und Optimierung numerischer Arrays vorgestellt Ihre Referenz. Ich werde im Folgenden nicht viel mehr sagen. Schauen wir uns die detaillierte Einführung an.
Gemeinsame zweischichtige Schleife zur Implementierung der Array-Deduplizierung
let arr = [11, 12, 13, 9, 8, 7, 0, 1, 2, 2, 5, 7, 11, 11, 7, 6, 4, 5, 2, 2] let newArr = [] for (let i = 0; i < arr.length; i++) { let unique = true for (let j = 0; j < newArr.length; j++) { if (newArr[j] === arr[i]) { unique = false break } } if (unique) { newArr.push(arr[i]) } } console.log(newArr)
Erstellen Sie einen Binärbaum zur Implementierung der Deduplizierung (nur anwendbar zu numerischen Typen Array)
Konstruieren Sie die zuvor durchlaufenen Elemente in einem Binärbaum. Jeder Knoten im Baum erfüllt: den Wert des linken untergeordneten Knotens< Wert des rechten untergeordneten Knotens
Dies optimiert den Prozess der Beurteilung, ob das Element schon einmal aufgetreten ist
Wenn das Element größer als der aktuelle Knoten ist, müssen Sie nur beurteilen, ob das Element vorhanden ist der rechte Teilbaum des Knotens Es muss nur vorher erscheinen
Wenn das Element kleiner als der aktuelle Knoten ist, müssen Sie nur feststellen, ob das Element im linken Teilbaum des Knotens erschienen ist
let arr = [0, 1, 2, 2, 5, 7, 11, 7, 6, 4,5, 2, 2] class Node { constructor(value) { this.value = value this.left = null this.right = null } } class BinaryTree { constructor() { this.root = null this.arr = [] } insert(value) { let node = new Node(value) if (!this.root) { this.root = node this.arr.push(value) return this.arr } let current = this.root while (true) { if (value > current.value) { if (current.right) { current = current.right } else { current.right = node this.arr.push(value) break } } if (value < current.value) { if (current.left) { current = current.left } else { current.left = node this.arr.push(value) break } } if (value === current.value) { break } } return this.arr } } let binaryTree = new BinaryTree() for (let i = 0; i < arr.length; i++) { binaryTree.insert(arr[i]) } console.log(binaryTree.arr)
Optimierungsideen 1. Notieren Sie die Maximal- und Minimalwerte
Notieren Sie die Maximal- und Minimalwerte der eingefügten Elemente Das größte Element oder das kleinste Element ist kleiner, direkt einfügen
let arr = [11, 12, 13, 9, 8, 7, 0, 1, 2, 2, 5, 7, 11, 11, 7, 6, 4, 5, 2, 2] class Node { constructor(value) { this.value = value this.left = null this.right = null } } class BinaryTree { constructor() { this.root = null this.arr = [] this.max = null this.min = null } insert(value) { let node = new Node(value) if (!this.root) { this.root = node this.arr.push(value) this.max = value this.min = value return this.arr } if (value > this.max) { this.arr.push(value) this.max = value this.findMax().right = node return this.arr } if (value < this.min) { this.arr.push(value) this.min = value this.findMin().left = node return this.arr } let current = this.root while (true) { if (value > current.value) { if (current.right) { current = current.right } else { current.right = node this.arr.push(value) break } } if (value < current.value) { if (current.left) { current = current.left } else { current.left = node this.arr.push(value) break } } if (value === current.value) { break } } return this.arr } findMax() { let current = this.root while (current.right) { current = current.right } return current } findMin() { let current = this.root while (current.left) { current = current.left } return current } } let binaryTree = new BinaryTree() for (let i = 0; i < arr.length; i++) { binaryTree.insert(arr[i]) } console.log(binaryTree.arr)
Optimierungsidee zwei, bauen Sie einen rot-schwarzen Baum
Bauen Sie einen roten -schwarzer Baum und balancieren Sie die Höhe des Baums aus
Informationen zu rot-schwarzen Bäumen finden Sie unter Rot-Schwarz-Einfügung des Baums
let arr = [11, 12, 13, 9, 8, 7, 0, 1, 2, 2, 5, 7, 11, 11, 7, 6, 4, 5, 2, 2] console.log(Array.from(new Set(arr))) class Node { constructor(value) { this.value = value this.left = null this.right = null this.parent = null this.color = 'red' } } class RedBlackTree { constructor() { this.root = null this.arr = [] } insert(value) { let node = new Node(value) if (!this.root) { node.color = 'black' this.root = node this.arr.push(value) return this } let cur = this.root let inserted = false while (true) { if (value > cur.value) { if (cur.right) { cur = cur.right } else { cur.right = node this.arr.push(value) node.parent = cur inserted = true break } } if (value < cur.value) { if (cur.left) { cur = cur.left } else { cur.left = node this.arr.push(value) node.parent = cur inserted = true break } } if (value === cur.value) { break } } // 调整树的结构 if(inserted){ this.fixTree(node) } return this } fixTree(node) { if (!node.parent) { node.color = 'black' this.root = node return } if (node.parent.color === 'black') { return } let son = node let father = node.parent let grandFather = father.parent let directionFtoG = father === grandFather.left ? 'left' : 'right' let uncle = grandFather[directionFtoG === 'left' ? 'right' : 'left'] let directionStoF = son === father.left ? 'left' : 'right' if (!uncle || uncle.color === 'black') { if (directionFtoG === directionStoF) { if (grandFather.parent) { grandFather.parent[grandFather.parent.left === grandFather ? 'left' : 'right'] = father father.parent = grandFather.parent } else { this.root = father father.parent = null } father.color = 'black' grandFather.color = 'red' father[father.left === son ? 'right' : 'left'] && (father[father.left === son ? 'right' : 'left'].parent = grandFather) grandFather[grandFather.left === father ? 'left' : 'right'] = father[father.left === son ? 'right' : 'left'] father[father.left === son ? 'right' : 'left'] = grandFather grandFather.parent = father return } else { grandFather[directionFtoG] = son son.parent = grandFather son[directionFtoG] && (son[directionFtoG].parent = father) father[directionStoF] = son[directionFtoG] father.parent = son son[directionFtoG] = father this.fixTree(father) } } else { father.color = 'black' uncle.color = 'black' grandFather.color = 'red' this.fixTree(grandFather) } } } let redBlackTree = new RedBlackTree() for (let i = 0; i < arr.length; i++) { redBlackTree.insert(arr[i]) } console.log(redBlackTree.arr)
Andere Deduplizierungsmethoden
Deduplizierung durch Set-Objekt
[...new Set(arr)]
Verwenden Sie die Methode sort()
+ reduce()
, um Duplikate zu entfernen.
Vergleichen Sie nach dem Sortieren benachbarte Objekte Elemente, um zu sehen, ob sie gleich sind, fügen Sie sie dem zurückgegebenen Array hinzu.
Es ist zu beachten, dass compare(2, '2')
beim Sortieren standardmäßig 0 zurückgibt; Der Vergleich wird durchgeführt
let arr = [0, 1, 2, '2', 2, 5, 7, 11, 7, 5, 2, '2', 2] let newArr = [] arr.sort((a, b) => { let res = a - b if (res !== 0) { return res } else { if (a === b) { return 0 } else { if (typeof a === 'number') { return -1 } else { return 1 } } } }).reduce((pre, cur) => { if (pre !== cur) { newArr.push(cur) return cur } return pre }, null)
bis includes()
+ map()
Methode zum Entfernen von Duplikaten
let arr = [0, 1, 2, '2', 2, 5, 7, 11, 7, 5, 2, '2', 2] let newArr = [] arr.map(a => !newArr.includes(a) && newArr.push(a))
bis includes()
+ reduce()
Methoden zum Entfernen von Duplikaten
let arr = [0, 1, 2, '2', 2, 5, 7, 11, 7, 5, 2, '2', 2] let newArr = arr.reduce((pre, cur) => { !pre.includes(cur) && pre.push(cur) return pre }, [])
Taste verwenden -Wert-Paare von Objekten + JSON-Objektmethoden zum Entfernen von Duplikaten
let arr = [0, 1, 2, '2', 2, 5, 7, 11, 7, 5, 2, '2', 2] let obj = {} arr.map(a => { if(!obj[JSON.stringify(a)]){ obj[JSON.stringify(a)] = 1 } }) console.log(Object.keys(obj).map(a => JSON.parse(a)))
Ich glaube, dass Sie die Methode beherrschen, nachdem Sie den Fall in diesem Artikel gelesen haben. Für weitere spannende Informationen achten Sie bitte auf andere verwandte Themen zum PHP-Chinesisch Website-Artikel!
Empfohlene Lektüre:
Grundlegende Leistungsoptimierung von Front-End-Webseiten
So verwenden Sie die gemischte Entwicklung von Android und HTML
Das obige ist der detaillierte Inhalt vonJS-Array-Deduplizierung numerischer Art. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!