我是R的新手,这可能是一个愚蠢的问题,但我不知道如何解决。
我有一个for循环,可能会返回i * j非空元素。
我想将所有非空结果存储在列表中,但如果我在循环中使用result[[i]]<-tmp
,它只能存储最多i
个元素,我如何能够存储所有列表中的值?感谢
result<-list()
for (i in 1:nrow(m)){
for (j in 1:i){
if(m[i,j]!=0 && m[j,i]!=0){
num=min(m[i,j],m[j,i])
tmp=c(i,j,num)
result[[i]]<-tmp
}
}
}
sample data
set.seed(123)
m= matrix(sample(0:5, size = 5*5, replace = TRUE), ncol = 5)
所需
row col min
[1] 1 1 1
[1] 2 2 3
[1] 3 1 2
[1] 3 2 2
[1] 3 3 4
[1] 4 1 5
[1] 4 2 1
[1] 4 4 1
[1] 5 1 5
[1] 5 2 2
[1] 5 4 5
[1] 5 5 3
Per David的回答
pmin(mx[upper.tri(mx, diag = TRUE)], mx[lower.tri(mx, diag = TRUE)])
[1] 1 0 2 5 2 3 5 1 0 1 3 0 1 5 3
返回
> result
[[1]]
[1] 1 1 2
[[2]]
[1] 2 2 3
[[3]]
[1] 3 3 4
[[4]]
[1] 4 4 2
[[5]]
[1] 5 5 4
答案 0 :(得分:3)
这里有@ DavidArenburg的回答(从评论中转换):
idx <- which(upper.tri(m,diag=TRUE),arr.ind=TRUE)
v <- pmin(m[idx], m[idx[,2:1]])
cbind(idx,min=v)[v>0,]
给出了
row col min
[1,] 1 1 1
[2,] 2 2 3
[3,] 1 3 2
[4,] 2 3 2
[5,] 3 3 4
[6,] 1 4 5
[7,] 2 4 1
[8,] 4 4 1
[9,] 1 5 5
[10,] 2 5 2
[11,] 4 5 5
[12,] 5 5 3