Ziggurat 矩阵不适用于 R 中的 "for" 和 "repeat" 循环 - 为什么?

Ziggurat matrix doesn't work with "for" and "repeat" loops in R - Why?

我是 R 的初学者。我不明白为什么 "for" 循环在我的矩阵中不起作用。我需要构建 ziggurat,我在其中输入 "n" 的函数必须 return 如图所示的矩阵。 screenshot 此代码适用于 n 等于 5 或​​小于 5。但是当它大于 5 时,"for" 循环不会 运行 遍历所有 (1:hunt) 数字。例如,见下图 screenshot 2 我尝试使用 "repeat" 循环,但它也不起作用。我的代码哪里出错了?

build_ziggurat <- function(n){
h<-1  
hunt <- n-4
if(n==1){
 m<- matrix(1, nrow = 1, ncol = 1)
  } else {
  if(n<5){
  d <- matrix(h, ncol = 2*n-h, nrow=2*n-h)
  d[2:(n+n-2),2:(n+n-2)]<-h+1;d
  d[(n-h):(n+h), (n-h):(n+h)]<-n-h;d
  d[n,n]<-n;d
  print(d)
} else {

  for(i in hunt:1){
    h<-1
      t <- matrix(h, ncol = 2*n-h, nrow=2*n-h)
      t[2:(n+n-2),2:(n+n-2)]<-h+1
      t[(n-h-i):(n+h+i), (n-h-i):(n+h+i)]<-(n-h-i)
      t[(n-h):(n+h),(n-h):(n+h)]<-n-h
      t[n,n]<-n
      return(t)

  }      

}
}
if(n==1) m
}      

您正在寻找类似的东西吗?

zigguratCreator <- function(n){
  out <- mat.or.vec(nr = (n - 1)*2 + 1, nc = (n - 1)*2 + 1) + 1
  for(i in seq(n - 1)){
    out[seq(i + 1, nrow(out) - i), seq(i + 1, ncol(out) - i)] <- i + 1
  }

  return(out)
}

zigguratCreator(n = 6)
zigguratCreator <- function(n){
  size <- 2*n-1
  out <- matrix(nr=size, nc=size)
  for(i in 1:size){
    for (j in 1:size){
      out[i,j] <-min(n-abs(i-n),n-abs(j-n))
    }
  }
  return(out)
}