我在R中有一个向量,其中至少包含50.000个实数。
值从小到大排序,现在我需要将此向量拆分为不同的向量。当两个数字之间的差大于给定数字(例如两个)时,必须拆分向量。

例子,

data <- c(1,1.1, 1.2, 4, 4.2, 8, 8.9, 9, 9.3);
# Then I need the following vectors:
x1 <- c(1, 1.1, 1.2);
x2 <- c(4, 4.2);
x3 <- c(8, 8.9, 9, 9.3);

困难在于我们不知道所需向量的数量,也不知道正手每个向量的长度。

现在,我有了以下想法,但是这非常耗时,并且只能将向量拆分为两个新向量。
j <- 2;
seqDemA1 <- seqDemandA[1];
while((seqDemandA[j-1] - seqDemandA[j] < 2) && (j < length(seqDemandA)+1)) {
    seqDemA1 <- c(seqDemA1, seqDemandA[j]);
    j <- j+1;
}
seqDemA2 <- seqDemandA[j];
j <- j+1;
while((seqDemandA[j-1] - seqDemandA[j] < 2) && (j < length(seqDemandA)+1)) {
    seqDemA2 <- c(seqDemA2, seqDemandA[j]);
    j <- j+1;
}

我期待着您的帮助!

最佳答案

试试这个,

split(data, cumsum(c(0, diff(data)>=2)))

09-25 18:54