35

假设我在 R 中有两个列表,不一定长度相等,例如:

 a <- list('a.1','a.2', 'a.3')
 b <- list('b.1','b.2', 'b.3', 'b.4')

构造交错元素列表的最佳方法是什么,一旦添加了较短列表的元素,较长列表的其余元素将附加在末尾?,例如:

interleaved <- list('a.1','b.1','a.2', 'b.2', 'a.3', 'b.3','b.4')

不使用循环。我知道mapply适用于两个列表长度相等的情况。

4

5 回答 5

43

这是一种方法:

idx <- order(c(seq_along(a), seq_along(b)))
unlist(c(a,b))[idx]

# [1] "a.1" "b.1" "a.2" "b.2" "a.3" "b.3" "b.4"

正如@James 指出的那样,既然你需要一个列表,你应该这样做:

(c(a,b))[idx]
于 2013-05-08T15:00:06.220 回答
33

在调查一个类似的问题时,我遇到了 Gabor Grothendieck(即@GGrothendieck?)在某些情况下的这个漂亮的解决方案:

c(rbind(a,b))

a当和b都是列表,或者当ab都是向量时,这同样适用。这不是 OP 问题的精确解决方案,因为当ab具有不同的长度时,它将回收较短序列的元素,打印警告。然而,由于这个解决方案简单而优雅,并且为一个非常相似的问题提供了答案——一些人(比如我)最终找到了这个页面的问题——它似乎值得添加作为答案。

于 2015-11-23T22:33:22.297 回答
5

这是使用ggplot2interleave中的函数的一个选项。我确信这可以改进,但这是一个开始:

require(ggplot2)
Interleave <- function(x,y){
    v <- list(x,y)
    lengths <- sapply(v,length)
    mn <- min(lengths)
    v <- v[order(lengths)]
    c(ggplot2:::interleave(v[[1]],v[[2]][seq_len(mn)]),v[[2]][(mn+1):length(v[[2]])])
}

Interleave(a,b)
Interleave(b,a)

特别是,如果列表实际上是相同的长度,这会做一些奇怪的事情。也许有人会提出一种更好的方法来v[[2]]在最后一行中进行索引,以避免这种退化的情况。

于 2013-05-08T14:59:26.607 回答
5
interleave(a, b)

# unlist(interleave(a, b))
# [1] "a.1" "b.1" "a.2" "b.2" "a.3" "b.3" "b.4"


interleave <- function(a, b) { 

  shorter <- if (length(a) < length(b)) a else b
  longer  <- if (length(a) >= length(b)) a else b

  slen <- length(shorter)
  llen <- length(longer)


  index.short <- (1:slen) + llen
  names(index.short) <- (1:slen)

  lindex <- (1:llen) + slen
  names(lindex) <- 1:llen


  sindex <- 1:slen
  names(sindex) <- 1:slen

  index <- c(sindex, lindex)
  index <- index[order(names(index))]

  return(c(a, b)[index])

}
于 2013-05-08T15:02:20.193 回答
2
a <- list('a.1','a.2', 'a.3')
b <- list('b.1','b.2', 'b.3', 'b.4')

interleave <- function(a, b) {
  mlab <- min(length(a), length(b)) 
  seqmlab <- seq_len(mlab) 
  c(rbind(a[seqmlab], b[seqmlab]), a[-seqmlab], b[-seqmlab]) 
}

interleave(a, b) 

来自http://r.789695.n4.nabble.com/Interleaving-elements-of-two-vectors-tp795123p1691409.html

这比@Arun快一点:

在此处输入图像描述

于 2019-05-11T14:23:19.560 回答