My task is to let user enter number n and then the matrix forms with dimensions n*n. Program then, makes diagonal have zeros, number above diagonal have to be positive numbers (1,2,...,n), and numbers below diagonal have to be negative numbers (-1,-2,...,-n). I successfully made the matrix after 8 hours of thinking, but the numbers below diagonal which must be negative, are positive. I cannot find where the problem is.
Input sample:
Enter n: 5
Matrix:
 0   1   2   3   4
-1   0   1   2   3
-2  -1   0   1   2
-3  -2  -1   0   1
-4  -3  -2  -1   0
My output:
Enter n: 5
Matrix:
 0   1   2   3   4
 1   0   1   2   3
 2   1   0   1   2
 3   2   1   0   1
 4   3   2   1   0
My code:
#include <bits/stdc++.h>
using namespace std;
void solve(long long n)
{
    long long array1[n - 1][n - 1], array2[n][n];
 
    for (long long i = 0; i < n - 1; ++i)
        array1[0][i] = i + 1;
 
    for (long long i = 1; i < n - 1; ++i)
        for (long long j = 0; j < n - 1; ++j)
            array1[i][j]
                = array1[i - 1][(j + 1) % (n - 1)];
 
    for (long long i = 0; i < n - 1; ++i)
        for (long long j = 0; j < n - 1; ++j)
            array2[i][j] = array1[i][j];
    for (long long i = 0; i < n; ++i)
        array2[i][n - 1] = array2[n - 1][i] = 0;
        for (long long i = 0; i < n; ++i) {
        long long t0 = array2[i][i];
        long long t1 = array2[i][n - 1];
 
        swap(array2[i][i], array2[i][n - 1]);
 
        array2[n - 1][i] = t0;
    }
    for (long long i = 0; i < n; ++i) {
        for (long long j = 0; j < n; ++j)
            cout << array2[i][j] << " ";
        cout << endl;
    }
}
 
int main()
{
    long long n = 5;
    solve(n);
 
    return 0;
}
 
     
    