Un equipo ha decidido que cada mañana alguien debería traer cruasanes para todos. No debería ser la misma persona cada vez, por lo que debería haber un sistema para determinar a quién le toca el turno. El propósito de esta pregunta es determinar un algoritmo para decidir a quién le tocará traer croissants mañana.
Restricciones, supuestos y objetivos:
- El turno de traer croissants se determinará la tarde anterior.
- En cualquier día, algunas personas están ausentes. El algoritmo debe elegir a alguien que estará presente ese día. Suponga que todas las ausencias se conocen con un día de anticipación, de modo que el comprador del cruasán se puede determinar la tarde anterior.
- En general, la mayoría de las personas están presentes la mayoría de los días.
- En aras de la equidad, todos deberían comprar cruasanes tantas veces como los demás. (Básicamente, suponga que cada miembro del equipo tiene la misma cantidad de dinero para gastar en croissants).
- Sería bueno tener algún elemento de aleatoriedad, o al menos percibir aleatoriedad, para aliviar el aburrimiento de una lista. Esto no es una restricción difícil: es más un juicio estético. Sin embargo, no se debe elegir a la misma persona dos veces seguidas.
- La persona que trae los cruasanes debe saberlo de antemano. Entonces, si la persona P debe traer cruasanes el día D, entonces este hecho debe determinarse en algún día anterior donde la persona P esté presente. Por ejemplo, si el portador de croissant siempre se determina el día anterior, entonces debe ser una de las personas que están presentes el día anterior.
- El número de miembros del equipo es lo suficientemente pequeño como para que los recursos informáticos y de almacenamiento sean efectivamente ilimitados. Por ejemplo, el algoritmo puede basarse en una historia completa de quién trajo croissants en el pasado. Hasta unos pocos minutos de cálculo en una PC rápida todos los días estaría bien.
Este es un modelo de un problema del mundo real, por lo que puede desafiar o refinar los supuestos si cree que modelan mejor el escenario.
Origen 1: Descubre quién comprará los cruasanes de Florian Margaine.
Origen 2: descubre quién va a comprar los cruasanes de Gilles.
Esta pregunta es la misma versión que la de Gilles y se ha vuelto a publicar en Programadores como un experimento para ver cómo las diferentes comunidades abordan un desafío de programación.