2016-04-12 149 views
0

我想在java中初始化一个Toeplitz矩阵。我希望它有这种形式
6 -4 1 0 0 ... 0 -4 6 -4 1 0 ... 0 1 -4 6 -4 1 ...0 ................ 0 ... 1 -4 6 -4 1 0 ... ...1 -4 6-4 0 .. ... 0 1 -4 6Toeplitz矩阵初始化

我意识到这个问题是在的data[i-j-1]边界的if(j>i)。我试图改变它,但我得到了IndexOutOfBounds错误。下面是我写到目前为止

int a1[][] = new int[size][size]; 


    int data[] = new int[size]; 

    data[0] = 6; 
    data[1] = -4; 
    data[2] = 1; 

    for(int i=3; i<size; i++){ 
     data[i] = 0; 
    } 

    /* Creating the A1 matrix */ 
    for(int i=0; i<size; i++) 
    { 
     for(int j=0; j<size; j++) 
     { 
      if(j>i){ 
       a1[i][j] = data[j-i-1]; 

      }else if(j==i){ 
       a1[i][j] = data[0]; 

      }else{ 
       a1[i][j] = data[i-j-1]; 
      } 


     } 
    } 

代码和输出

The Matrix is : 
6 6 -4 1 0 0 0 0 0 0 
6 6 6 -4 1 0 0 0 0 0 
-4 6 6 6 -4 1 0 0 0 0 
1 -4 6 6 6 -4 1 0 0 0 
0 1 -4 6 6 6 -4 1 0 0 
0 0 1 -4 6 6 6 -4 1 0 
0 0 0 1 -4 6 6 6 -4 1 
0 0 0 0 1 -4 6 6 6 -4 
0 0 0 0 0 1 -4 6 6 6 
0 0 0 0 0 0 1 -4 6 6 

回答

1

的问题是,如果i = j+1j = i+1a1分配a1[i][j] = data[0]。这是一个错误,你应该删除1:

for(int j=0; j<size; j++) { 
    if(j>i){ 
     a1[i][j] = data[j-i]; 
    }else if(j==i){ 
     a1[i][j] = data[0]; 
    }else{ 
     a1[i][j] = data[i-j]; 
    } 
}