我有一个嵌套列表,如下所示:
results <- list()
c <- 1
outcomes <- c("Value1", "Value2", "Value3")
values <- c(2, 11, 20)
for(i in outcomes){
for(p in 1:length(values)){
results[[c]] <- c(outcomes[p], values[p])
c <- c + 1
}
}
results <- results[1:3]
>results
[[1]]
[1] "Value1" "2"
[[2]]
[1] "Value2" "11"
[[3]]
[1] "Value3" "20"
我想找到一种方法来返回具有最高值的货币对,如下所示:"Value3" "20"
我该如何仅使用基r来做到这一点?
答案 0 :(得分:0)
也许这会有所帮助:
#Code
results[which(unlist(lapply(results,function(x) as.numeric(x[2])))==max(unlist(lapply(results,function(x) as.numeric(x[2])))))]
输出:
[[1]]
[1] "Value3" "20"
答案 1 :(得分:0)
我们可以提取list
中的第二个元素unlist
,将其转换为numeric
,用which.max
找到max元素的索引以提取{{1 }}
list
或稍微紧凑
results[which.max(as.numeric(unlist(sapply(results, `[`, 2))))]
#[[1]]
#[1] "Value3" "20"