Ответ 1
Вот решение. Поэтому он легко читается здесь, я разбил код на две части. Позже вы можете легко объединить две части в одну функцию.
Во-первых, функция, которая получает матрицу всех имен, используя рекурсию:
anames <- function(x) {
require(plyr)
if (is.data.frame(x)) return(NA)
y <- do.call(rbind.fill.matrix,
mapply(cbind, names(x), lapply(x, anames),
SIMPLIFY = FALSE))
colnames(y) <- NULL
return(y)
}
anames(a)
# [,1] [,2] [,3] [,4]
# [1,] "b1" "c1" "d1" NA
# [2,] "b1" "c2" NA NA
# [3,] "b2" NA NA NA
Затем, функция, которая применяет данный ввод steps
, и заполняет NA
, как вы просили:
listToMatrix <- function(myList, steps = Inf) {
a <- anames(myList)
steps <- min(steps, ncol(a) - 1)
cols.idx <- seq_len(steps)
a <- a[, cols.idx]
for (j in tail(cols.idx, -1))
a[, j] <- ifelse(is.na(a[, j]), a[, j - 1], a[, j])
return(a)
}
listToMatrix(a, 2)
# [,1] [,2]
# [1,] "b1" "c1"
# [2,] "b1" "c2"
# [3,] "b2" "b2"