如何从for循环中存储结果列表

qsh*_*hng 6 loops r

我是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)
Run Code Online (Sandbox Code Playgroud)

期望

 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
Run Code Online (Sandbox Code Playgroud)

每个大卫的回答

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
Run Code Online (Sandbox Code Playgroud)

回报

      > 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
Run Code Online (Sandbox Code Playgroud)

Fra*_*ank 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,]
Run Code Online (Sandbox Code Playgroud)

这使

      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
Run Code Online (Sandbox Code Playgroud)