Versuchen Sie d <- unlist(lapply(time,function(i)seq.int(0,i-1)))
Eine Nebenbemerkung: Eine Sache, die die ganze Sache verlangsamt, ist die Tatsache, dass der Vektor innerhalb der Schleife wächst.
> time<-sample(seq(1000,10000,by=1000),1000,replace=T)
> system.time({
+ d<-NULL
+ for ( i in seq(length(time)))
+ d<-c(d,seq(0,(time[i]-1)))
+ }
+ )
user system elapsed
9.80 0.00 9.82
> system.time(d <- unlist(lapply(time,function(i)seq.int(0,i-1))))
user system elapsed
0.00 0.00 0.01
> system.time(unlist(mapply(seq, 0, time-1)))
user system elapsed
0.11 0.00 0.11
> system.time(sequence(time) - 1)
user system elapsed
0.15 0.00 0.16
Edit : Zeitangaben auch für andere Lösungen hinzugefügt