trudno mi wymyślić szybkiego rozwiązania następującego problemu:Wektoryzacja pętli nad elementów wektorów
Mam wektor obserwacji, który wskazuje czas obserwacji pewnych zjawisk.
example <- c(0,0,0,1,0,1,1,0,0,0,-1,0,0,-1,-1,0,0,1,0,0);
Teraz chciałbym wyeliminować zer pomiędzy poszczególnymi obserwacji, biorąc pod uwagę, że zakłada się pewien fenomen, aby kontynuować aż do sprzecznych obserwacji zauważyć, tzn jeśli „” 1 „” zaobserwowano w trzeciej obserwacji, ja chciałby mieć tylko "1" do 11 elementu, gdy pierwszy "-1" jest obserwowany. Więc moja pożądane wyjście wygląda następująco:
desired.output <- c(0,0,0,1,1,1,1,1,1,1,-1,-1,-1,-1,-1,-1,-1,1,1,1);
> print(cbind(example, desired.output))
example desired.output
[1,] 0 0
[2,] 0 0
[3,] 0 0
[4,] 1 1
[5,] 0 1
[6,] 1 1
[7,] 1 1
[8,] 0 1
[9,] 0 1
[10,] 0 1
[11,] -1 -1
[12,] 0 -1
[13,] 0 -1
[14,] -1 -1
[15,] -1 -1
[16,] 0 -1
[17,] 0 -1
[18,] 1 1
[19,] 0 1
[20,] 0 1
My lame rozwiązaniem jest
for (i in 1:length(example)){
if (example[i] != 0){
current <- example[i];
while ((example[i] != -current) & (i <= length(example))){
example[i] <- current;
i <- i+1;
}
}
}
Będę wdzięczni za każdą pomoc w przyspieszeniu tego.
+1 Update2 jest niesamowicie dobry. Niezłe. –
+1 dla czystej -R najwyższej prędkości w UPD2 – gagolews
Dzięki, genialny dwurzędowy. – Banach