Un collega è venuto da me con un problema interessante, uno pratico che ha a che fare con un gruppo di "nuove persone in città" di cui fa parte.Algoritmo combinatorio per l'assegnazione di persone ai gruppi
18 amici vogliono cenare in gruppo per ciascuno dei prossimi 4 giorni. Le regole sono le seguenti:
- Ogni giorno il gruppo si dividerà in 4 gruppi di 4, e un gruppo di 2.
- qualsiasi coppia di persone sarà solo vedere l'altro più di una volta nel corso della i 4 giorni.
- Una determinata persona farà parte una volta al massimo del gruppo di dimensioni 2.
Una ricerca ricorsiva di forza bruta per un insieme valido di assegnazione di gruppo è ovviamente poco pratica. Ho gettato in una logica semplice per potare parti dell'albero il prima possibile, ma non abbastanza per renderlo pratico.
In realtà, sto iniziando a sospettare che potrebbe essere impossibile seguire tutte le regole, ma non riesco a trovare un argomento combinatorio per il motivo.
Qualche idea?
Possibile regola la potatura: non si dispone di un gruppo di 18 persone, si dispone di una serie di 10 persone che saranno in un gruppo di 4 ogni notte, e una serie di 8 persone che sarà in un gruppo di 2 una volta. –