Un compañero de trabajo vino a mí con un problema interesante, uno práctico que tiene que ver con un grupo de "gente nueva en la ciudad" del que es parte.Algoritmo combinatorio para asignar personas a grupos
18 amigos quieren cenar en grupos para cada uno de los próximos 4 días. Las reglas son como sigue:
- Cada día el grupo se divide en 4 grupos de 4, y un grupo de 2.
- cualquier par de personas dado sólo verá entre sí como máximo una vez en el transcurso de los 4 días.
- Cualquier persona determinada solo será parte del grupo de tamaño 2 como máximo una vez.
Una fuerza bruta de búsqueda recursiva para un conjunto válido de asignación de grupo es obviamente impracticable. Introduje una lógica simple para podar partes del árbol lo antes posible, pero no lo suficiente como para hacerlo práctico.
En realidad, estoy empezando a sospechar que podría ser imposible seguir todas las reglas, pero no puedo presentar un argumento combinatorio sobre por qué sería eso.
¿Alguna idea?
regla de poda posible: usted no tiene un grupo de 18 personas, que tienen un conjunto de 10 personas que estarán en un grupo de 4 cada noche, y un conjunto de 8 personas que van a estar en una grupo de 2 una vez. –