Uda*_*rya 1 arguments if-statement r
在以下代码中:
det<-function(M)
{
if (nrow(M) == 2)
{
return(M[1,1]*M[2,2]-M[1,2]*M[2,1])
}
else
{
d<-0
for (i in 1:ncol(M))
{
d<-d+(-1)^(i+1)*M[1][i]*det(M[-1,i])
}
return(d)
}
}
Run Code Online (Sandbox Code Playgroud)
执行我确定的功能
x<-matrix(c(1:9),nrow=3)
Run Code Online (Sandbox Code Playgroud)
执行功能时
det(x)
Run Code Online (Sandbox Code Playgroud)
我收到错误:
if(nrow(M)== 2){:参数的长度为零时出错
您正在使用递归函数,问题出在以下行:
d<-d+(-1)^(i+1)*M[1][i]*det(M[-1,i])
Run Code Online (Sandbox Code Playgroud)
在这里,您将使用M[-1, i]
矩阵的子集,R将矩阵转换为数字向量(R在子集化时始终转换为最简单的数据类型).您可以设置参数drop=FALSE
以避免这种情况.查看?"["
并?drop
了解详情.
x <- matrix(1:9, nrow=3)
x[-1, 1]
# [1] 2 3
x[-1, 1, drop=FALSE]
# [,1]
# [1,] 2
# [2,] 3
Run Code Online (Sandbox Code Playgroud)
(请注意,即使你修复了这个问题,你的功能也会失败.在你的if语句中,你访问第二列,但M[-1, i]
总是只有一列.)