El algoritmo de Lee es una solución posible para problemas de enrutamiento de laberinto. Siempre da una solución óptima, si existe, pero es Lento y requiere gran memoria para un diseño denso.
### Entendiendo como funciona
El algoritmo es un algoritmo basado en `breadth-first` que usa `queues` para almacenar los pasos. Por lo general, utiliza los siguientes pasos:
1. Elija un punto de partida y agréguelo a la cola.
2. Agregue las celdas vecinas válidas a la cola.
3. Elimine la posición en la que se encuentra de la cola y continúe con el siguiente elemento.
4. Repita los pasos 2 y 3 hasta que la cola esté vacía.
### Implementación
C ++ ya tiene la cola implementada en la biblioteca `<queue>` , pero si está utilizando algo más, puede implementar tu propia versión de la cola.