Hola
Nuevamente necesito ayuda de ustedes, en muy pocas oportunidades escribà una función, dirÃa que no tengo experiencia al respecto.
Escribo el código en R (copiar y pegar) con los comentarios y descripción de los datos.
Esperando que se entienda  ...
#######################################################
# Â Â Descricion de los datos (en orden de columnas)
# Â 5 Personas que realizan una actividad,
# Â por cada vez que se realiza se la numera
# Â cada actividad numerada es realizada a x dias desde
# Â la columna dias2 es generada para no tener blancos (vacÃos)
persona<-c(1,1,1,1,1,2,2,2,2,2,3,3,3,4,5,5)
numeracion <-c(1,2,3,4,5,1,2,3,4,5,1,2,3,1,1,2)
dias <-c(1,3,4,6,9,2,4,6,7,9,2,5,8,3,5,8)
dias2 <- c(1:length(dias))
datos <- data.frame(persona, numeracion, dias, dias2)
datos
#   descripción de lo que deberÃa realizar
# Â Â observar la columna dias2
# Â Â cambia el primer valor y los ultimos (15 y 16)
datos$dias2[datos$dias2 < max(datos$dias2)] <- datos$dias2[-1]
datos$dias2[datos$dias2 == max(datos$dias2)] <- NA
datos
#  al observar las columnas dÃas y dÃas2 me es fácil restar
# Â entre ambas columnas para obtener la diferencia de tiempo
###########
# Â Mi problema
# Â lo descripto anteriormente debe tomar el valor maximo de cada
# Â persona, no el maximo de todo el data.frame
#  (un max por persona)  y   (un [-1] por persona)
# Â intente vosas como:
# Â probar <- do.call(rbind, by(datos, datos$persona, datos$dias, function(x){...
# Â todos intentos que no fueron correctos
#  ¿Me explico? ¿Ideas?
    [[alternative HTML version deleted]]