我目前正在学校学习R,我被这个问题困住了:

这是我的密码:
logistic.map <- function(N0, r, K, tmax) {
length(N) <- tmax
N[1] <- N0
for (i in 1:tmax) N[i+1] <- N[i] + r * N[i] * (1 - N[i] / K)
return(list(t = 0:tmax, N = tmax))
}
r1 <- logistic.map(2,0.2,100,50)
r2 <- logistic.map(2,2.2,100,50)
r3 <- logistic.map(2,2.9,100,50)
xlab="Years"
ylab="Population"
plot(r1$t, r1$N, xlab=xlab, ylab=ylab)
plot(r2$t, r2$N, xlab=xlab, ylab=ylab)
plot(r3$t, r3$N, xlab=xlab, ylab=ylab)每当我运行它时,它都会返回错误:
Error in logistic.map(2, 0.2, 100, 50) : object 'N' not found
Error in logistic.map(2, 2.2, 100, 50) : object 'N' not found
Error in logistic.map(2, 2.9, 100, 50) : object 'N' not found有人能帮我找出我做错了什么吗?非常感谢!
发布于 2018-09-29 21:22:16
在函数中初始化输出向量的方法是不正确的。使用N <- numeric(tmax + 1)而不是length(N) <- tmax。R中的向量使用基于1的索引,而不是基于0的索引.
对于返回的值,请使用return(list(t = 0:tmax, N = N))。
https://stackoverflow.com/questions/52572606
复制相似问题