I'm trying to find if a matrix [][] is symmetric in different orientations (horitzonzal/ vertical or both), and found this tutorial https://www.geeksforgeeks.org/check-horizontal-vertical-symmetry-binary-matrix/ and tried it with my matrixes, but it doesn't seem to work correctly. Here is my current code and the output I get:
Example Matrix:
111
144
144
I call the method from the tutorial by:
// test for symmetrie
checkHV(matrix, rows, colums);
Where rows and colums in this case are both 3. From my opinion, it should output NO, but the current output is VERTICAL (always, with all matrixes..). Why is that? And how could I modify the code so that it works correctly for me? Thanks!
And here the code from the tutorial:
static void checkHV(int [][]arr, int N,
int M)
{
// Initializing as both horizontal
// and vertical symmetric.
boolean horizontal = true;
boolean vertical = true;
// Checking for Horizontal Symmetry.
// We compare first row with last
// row, second row with second
// last row and so on.
for (int i = 0, k = N - 1;
i < N / 2; i++, k--)
{
// Checking each cell of a column.
for (int j = 0; j < M; j++)
{
// check if every cell is identical
if (arr[i][j] != arr[k][j])
{
horizontal = false;
break;
}
}
}
// Checking for Vertical Symmetry. We compare
// first column with last column, second xolumn
// with second last column and so on.
for (int i = 0, k = M - 1;
i < M / 2; i++, k--)
{
// Checking each cell of a row.
for (int j = 0; j < N; j++)
{
// check if every cell is identical
if (arr[i][j] != arr[k][j])
{
horizontal = false;
break;
}
}
}
if (!horizontal && !vertical)
System.out.println("NO");
else if (horizontal && !vertical)
System.out.println("HORIZONTAL");
else if (vertical && !horizontal)
System.out.println("VERTICAL");
else
System.out.println("BOTH");
}
EDIT: After changing horitzontal = true for vertical = true, the code still doesn't work propertly with rectangle Matrixes, so f.e. 4*2, giving me an array out of bounds.. Matrix:
1112
2212
with row = 2 and column = 4..
Try this: