Estoy tratando de encontrar una implementación eficiente del árbol de intervalos de C++ (en su mayoría basada en árboles negros rojos) sin una licencia viral o restrictiva. ¿Alguna sugerencia para una implementación limpia, liviana e independiente? Para el caso de uso que tengo en mente, el conjunto de intervalos se conoce desde el principio (habría, digamos, un millón) y quiero ser capaz de obtener rápidamente una lista de intervalos que se superponen a un intervalo determinado. Por lo tanto, el árbol una vez construido no cambiará, solo necesita consultas rápidas.Encontrando la implementación del algoritmo del árbol de intervalos C++
Respuesta
La biblioteca estándar de C++ ofrece árboles rojos/negros std::map
, std::multimap
, std::set
y std::multiset
.
verdad, no se me ocurre ninguna manera de manejar esto con más eficiencia que para mantener un std::map
de pares de iterador, y pasando esos pares de iterador a upper_bound()
y lower_bound()
. Querrá que los pares de iteradores se mantengan en un mapa para que pueda centrarse fácilmente en los pares que probablemente estén en el intervalo (si el iterador de inicio en el "intervalo de candidato" aparece después del final del intervalo dado) estás mirando, entonces puedes omitir el chequeo de eso, y todos los pares de iteradores posteriores).
He escrito una implementación de árbol de intervalos basada en plantilla en C++, https://github.com/ekg/intervaltree. Licencia de MIT Disfrutar.
Tenga en cuenta que esta implementación no puede alterar el árbol una vez que se ha construido, es decir, que construye árboles de intervalos estáticos. Mire http://web.mit.edu/~emin/www.old/source_code/cpp_trees/index.html para árboles 'dinámicos'. – logion
También hay una implementación de C# del árbol Intervalo en this link. Es bastante fácil traducir a C++ para los necesitados
- 1. ¿Busca la implementación del árbol de sufijos en C#?
- 2. Implementación de C# del algoritmo Bron-Kerbosch
- 3. C++ R - implementación del árbol deseada
- 4. Implementación del algoritmo C5?
- 5. Implementación del algoritmo Bentley-Ottmann
- 6. Implementación del algoritmo de Dijkstra
- 7. implementación del árbol de sufijos en python
- 8. Implementación máxima del algoritmo de rectángulo
- 9. Implementación del algoritmo de ordenación más segura
- 10. javascript implementación del árbol de búsqueda binaria
- 11. Implementación C# del 'Algoritmo de polilínea codificada' de Google
- 12. Implementación de Python del algoritmo de Viterbi
- 13. Implementación del algoritmo Bentley-Ottmann existente
- 14. Implementación de Python del algoritmo OPTICS (Clustering)
- 15. Implementación del algoritmo de Luhn en Ruby
- 16. Implementación del algoritmo de triangulación Chazelle
- 17. problema del vendedor ambulante, algoritmo 2-opt implementación C#
- 18. Implementación del algoritmo DPLL en Prolog
- 19. Implementación MySQL del algoritmo Ray-Casting?
- 20. Encontrando altura en Árbol de búsqueda binaria
- 21. Algoritmo de árbol de intervalo que admite la fusión de intervalos sin superposición
- 22. Aplicación del Rojo-Negro Árbol en C#
- 23. Recorrido del árbol Z3_ast en C/C++
- 24. Árbol binario del árbol general
- 25. encontrando dos elementos más distantes en un árbol binario
- 26. Visualización del algoritmo para C#
- 27. ¿Encontrando el valor mínimo del grupo máximo?
- 28. Implementación del algoritmo de inferencia de tipo Damas-Hindley-Milner
- 29. Implementación de Python del algoritmo de alineación BLAST?
- 30. Centro de búsqueda del árbol
¿Podría explicar esto un poco más sobre cómo se puede implementar el mapa/conjunto como árboles de intervalo? – Kyuubi
@Kyuubi: sugerí implementar un árbol de intervalos con 'std :: map' /' std :: set' (es decir, comenzando con 'std :: map' /' std :: set' y terminando con un árbol de intervalos ; ** NO ** comenzando con un árbol de intervalos e implementando un 'std :: map',' std :: set'). –
@Kyuubi Al irme de la memoria, creo que la idea era simplemente que tuvieras (1) una colección de cosas, (2) una lista de intervalos en esa colección que estabas viendo, (3) definiste los intervalos con ' begin' y 'end' iterators. Entonces, usando un 'std :: map', podría simplemente hacer que el iterador' begin' sea la clave, y el iterador 'end' correspondiente sea el valor. Con esto, no puede encontrar todos los intervalos que desea en una toma, pero puede reducir los intervalos que necesita para filtrar. –