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;
}