次のようなベクトルがありc(1, 3, 4, 5, 9, 10, 17, 29, 30)
、規則的な連続シーケンスを形成する「隣接する」要素をグループ化したいと思います。つまり、1ずつ増加し、次のような不規則なベクトルになります。
L1:1
L2:3,4,5
L3:9,10
L4:17
L5:29,30
(元Cプログラマーの)ナイーブなコード:
partition.neighbors <- function(v)
{
result <<- list() #jagged array
currentList <<- v[1] #current series
for(i in 2:length(v))
{
if(v[i] - v [i-1] == 1)
{
currentList <<- c(currentList, v[i])
}
else
{
result <<- c(result, list(currentList))
currentList <<- v[i] #next series
}
}
return(result)
}
これで、a)RはCではない(中括弧にもかかわらず)
b)グローバル変数は純粋な悪
であるc)結果を達成するためのひどく非効率的な方法であることがわかりました
、したがって、より良い解決策は大歓迎です。