Мне трудно найти быстрое решение следующей проблемы:
У меня есть вектор наблюдений, который указывает время наблюдения определенных явлений.
example <- c(0,0,0,1,0,1,1,0,0,0,-1,0,0,-1,-1,0,0,1,0,0);
Теперь я хотел бы устранить нули между конкретными наблюдениями, учитывая, что предполагается, что определенное явление продолжается до тех пор, пока не будет отмечено противоречивое наблюдение, т.е. если в третьем наблюдении наблюдалось "1", я хотел бы иметь только "1" до 11-го элемента, когда наблюдается "-1". Поэтому мой желаемый результат выглядит следующим образом:
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
Мое хромое решение
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;
}
}
}
Я буду признателен за любую помощь в ускорении этого.