找到矩阵的对角元素

时间:2016-07-07 09:27:21

标签: r

我编写了一个函数来将矩阵的对角元素存储到向量中。但输出并不像我预期的那样。代码是

diagonal <- function(x) {
for( i in nrow(x)){ 
for(j in ncol(x)){
  if(i == j) { 
    a <- x[i,j]
  } 
}
}
print(a)
}

我将矩阵传递给函数。 代码有什么问题?

1 个答案:

答案 0 :(得分:2)

我们可以使用diag函数

diag(m1)
#[1] 1 5 9

或者

m1[col(m1)==row(m1)]
#[1] 1 5 9

如果我们使用for循环,我们按行和列的顺序循环,即1:nrow(x)/1:ncol(x),而不是nrow(x)/ncol(x)

diagonal <- function(x) {
  a <- numeric(0)
 for( i in 1:nrow(x)){ 
  for(j in 1:ncol(x)){
     if(i == j) { 
       a <-  c(a, x[i,j])
     } 
    }
  }
 a
 }

diagonal(m1)
#[1] 1 5 9

数据

m1 <- matrix(1:9, ncol=3)