O algoritmo de Lee é uma solução possível para problemas de roteamento de labirinto. Sempre dá uma solução ótima, se existir, mas é lento e requer grande memória para layout denso.
### Entendendo como funciona
O algoritmo é um algoritmo baseado em `breadth-first` que usa `queues` para armazenar as etapas. Geralmente, ele usa as seguintes etapas:
1. Escolha um ponto de partida e adicione-o à fila.
2. Adicione as células vizinhas válidas à fila.
3. Remova a posição da fila e continue até o próximo elemento.
4. Repita as etapas 2 e 3 até que a fila esteja vazia.
### Implementação
O C ++ já tem a fila implementada na biblioteca `<queue>` , mas se você estiver usando algo mais, será bem-vindo para implementar sua própria versão da fila.