Wo kann ich einen gebrauchsfertigen finden? Oder eine gute Sammlung von "Standard" -Datenstrukturen, wenn Sie welche kennen?Javascript: Benötigen Sie eine anständige rote schwarze Baumimplementierung
Antwort
Eine schnelle Überprüfung o‘wandten sich die Interwebs eine ready-to-use Implementierung von Kevin Lindsey (nach unten scrollen zu Rot-Schwarz-Bäume) nach oben:
Leider eines weiß ich nicht Site, die ein Repository von vorgefertigten komplexen Datenstrukturen hat.
Ich vermute, dass sie ein bisschen selten sind, da Leute selten JavaScript für die Art des schweren Anhebens verwenden, das diese Arten der komplexen Strukturen erfordern würde ... aber ich könnte falsch liegen.
Ich frage mich, warum sie selten sind, wenn man bedenkt, wie ubiquitär Javascript im Allgemeinen ist ... – Hamster
Diese Implementierung ist eigentlich von einem AVL-Baum, und fälschlich als Red-Black-Tree bezeichnet! Immer noch O (log n). – smilingthax
schrieb ich einen rot-schwarzen Baum in Javascript, finden Sie hier: https://github.com/vadimg/js_bintrees oder als bintrees
in npm. Im Gegensatz zu den anderen Implementierungen gibt es Unit-Tests.
Warum brauchen Sie einen rot-schwarzen Baum, wenn JavaScript-Objektliterale das Gleiche tun und wahrscheinlich sowieso als rot-schwarzer Baum in C implementiert werden? (könnte auch als eine Hash-Tabelle implementiert werden, die ähnliche Leistungsmerkmale aufweisen würde). – slebetman
Um ein wenig pedantisch zu sein: Rot-Schwarz-Bäume haben garantiert Log-Verhalten, auch im schlimmsten Fall, aber Hash-Tabellen bieten diese Garantie nicht. Ein weiterer Unterschied besteht darin, dass Rot-Schwarz-Bäume funktionsfähig gemacht werden können, was je nach Anwendung nützlich sein kann. – dyoo