El algoritmo Even-Paz es un algoritmo computacionalmente eficiente para cortar el pastel de manera justa . Es para algún recurso divisible heterogéneo, como un pastel de cumpleaños, entre n participantes con diferentes preferencias por diferentes partes del pastel. El algoritmo permite que n personas obtengan una división proporcional .
El primer algoritmo publicado para la división proporcional del pastel fue el último algoritmo decreciente , publicado en 1948, que tenía complejidad . En 1984, los matemáticos israelíes Shimon Even y Azariah Paz publicaron un algoritmo mejorado cuya complejidad era [1] .
El algoritmo utiliza una estrategia de divide y vencerás y es capaz de dar una división proporcional en el tiempo .
Se puede demostrar por inducción que cualquier socio que juega según las reglas garantiza un valor de al menos 1/ n , independientemente del comportamiento de los otros socios.
Gracias a la estrategia divide y vencerás, el número de iteraciones es solo O(log n ), a diferencia de O( n ) para el último procedimiento reducido. En cada iteración, se requiere un token de cada socio. Por lo tanto, el número de marcadores requeridos es .
Unos años después de la publicación del algoritmo de Even-Paz, se demostró que cualquier procedimiento de división proporcional determinista o aleatoria que asigna a cada participante una pieza continua debe utilizar acciones [2] .
Además, cualquier procedimiento de división proporcional determinista debe utilizar acciones, incluso si se permite que el procedimiento dé al participante una parte que no sea continua, e incluso si se permite que el procedimiento garantice solo una equidad aproximada [3] [4] .
De estos resultados de dificultad del algoritmo se deduce que el algoritmo Even-Paz es el algoritmo más rápido para lograr una proporcionalidad total con piezas continuas, y este algoritmo es el más rápido para obtener una proporcionalidad incluso parcial e incluso con piezas discontinuas. El único caso en el que se puede mejorar el algoritmo es en algoritmos aleatorios que garanticen proporcionalidad parcial con trozos discontinuos. Ver " Algoritmo de Edmonds-Prus ".
Puede utilizar la aleatorización para reducir el número de marcadores. La siguiente versión aleatoria del procedimiento de bisección recursiva logra la división proporcional usando solo consultas de etiquetado O( n ) en promedio [1] . La idea es que en cada iteración, en lugar de pedir a todos los participantes que marquen en el medio, solo se les pide a unos pocos socios que hagan dichos marcadores, mientras que otros socios solo eligen la mitad que prefieren. Los socios se envían al oeste o al este según su preferencia hasta que el número de socios en cada lado sea n /2. Luego se hace un corte y cada grupo de n /2 socios divide su mitad recursivamente [5] .
En el peor de los casos, todavía necesitamos n -1 marcadores por iteración, por lo que el número de marcadores necesarios es O( n log n ) en el peor de los casos. Sin embargo, en el caso promedio, solo necesita marcadores O(log n ) por iteración. Al resolver la relación de recurrencia , se puede demostrar que el número de marcadores requeridos es O( n ).
Tenga en cuenta que el número total de solicitudes sigue siendo O ( n log n ), ya que cada socio debe elegir la mitad.