托普利茨矩阵初始化

Toeplitz matrix initialization

我正在尝试在 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 6

我意识到问题出在 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   

问题是如果 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];
    }
}