Broad Network


9.9 Print matrix in zig-zag fashion, in C.

9. Basic Matrix Algorithm Problems in C

Full Course on Data Structures and Algorithms in C

By: Chrysanthus Date Published: 16 May 2026

The reader is advised to read all the lessons (tutorials) in this full course, in the order presented.

Problem

Given a matrix of 2D array of n rows and m columns, print this matrix in ZIG-ZAG fashion as shown in the following figure:

Example 1: 
Input: mat[][] = {{1, 2, 3}
                  {4, 5, 6}
                  {7, 8, 9}}

Output : 1, 2, 4, 7, 5, 3, 6, 8, 9

Example 2: 
Input: mat[][] = {{1,  2,  3,  4,  5}, 
                  {6,  7,  8,  9,  10},
                  {11, 12, 13, 14, 15},
                  {16, 17, 18, 19, 20}};

Output : 1, 2, 6, 11, 7, 3, 4, 8, 12, 16, 17, 13, 9, 5, 10, 14, 18, 19, 15, 20

Solution in O(n x m) Time

The algorithm is as follows:

- Visit the top-left element first. Visit the next element on the right.
- Continue visiting the current minor diagonal elements in the left-downwards direction until meeting the left edge or bottom edge of the matrix.
- If the left edge of the matrix is met and not the bottom edge, visit the next element below.
- Continue visiting the current minor diagonal elements in the right-upwards direction until meeting the top edge or right edge of the matrix.
- If the bottom edge of the matrix was met, and not the left edge, then visit the next element on the right at the bottom edge.
- Continue visiting the current minor diagonal elements in the right-upwards direction until meeting the top edge or right edge of the matrix.
- If the top edge of the matrix is met and not the right edge, visit the next element on the right.
- Continue visiting the current minor diagonal elements in the left-downwards direction until meeting the left edge or bottom edge of the matrix.
- If the right edge of the matrix was met, and not the top edge, then visit the next element below.
- Continue visiting the current minor diagonal elements in the left-downwards direction until meeting the left edge or bottom edge of the matrix.
- Continue repeating the above steps accordingly, until the element at the bottom-right corner of the matrix is met, which will always be met, either from the left or from above.
- Do not forget to consider the cases, where the visit is at the four corners.

There are eight cases to consider: when the visit is at the four corners and when the visit is at the four edges. The case of what happens after the visit of the bottom-right element, does not have to be addressed. This gives rise to seven code segments in a major while-loop.

Indexes

The top most row of the matrix is identified by i=0.
The leftmost column of the matrix is identified by j=0.
The bottommost row of the matrix is identified by i=n-1.
The rightmost column of the matrix is identified by j=m-1.

The program

The program is (read through the code and comments):

#include <stdio.h>

void zigZagMatrix(int mat[][5], int n, int m) {
    int i=0, j=0;
    
    while (i < n && j < m) {
        if (i == 0 && j == 0) {    //top-left corner
            printf("%i, ", mat[i][j]);
            j++;    //go right once
            printf("%i, ", mat[i][j]);
            while (j > 0 && i < n-1) {    //end at left or bottom edge
                i++; j--;    //go down and left
                printf("%i, ", mat[i][j]);
            }
        }
        
        if (j == 0 && i > 0 && i < n-1) {    //left edge and not top or bottom ends
            i++;    //go down once
            printf("%i, ", mat[i][j]);
            while (i > 0 && j < m - 1) {    //end at top or right edge
                i--; j++;   //go right and up
                printf("%i, ", mat[i][j]);
            }
        }
        
        if (i == 0 && j > 0 && j < m-1) {    //top edge and not left or right ends 
            j++;    //go right once
            printf("%i, ", mat[i][j]);
            while (j > 0 && i < n-1) {    //end at left or bottom edge
                i++; j--;    //go down and left
                printf("%i, ", mat[i][j]);
            }
        }
        
        if (i == n-1 && j == 0) {    //left-bottom corner
            j++;    //go right once
            printf("%i, ", mat[i][j]);
            while (i > 0 && j < m - 1) {    //end at top or right edge
                i--; j++;   //go right and up
                printf("%i, ", mat[i][j]);
            }
        }
        
        if (i == 0 && j == m-1) {    //top-right corner
            i++;    //go down once
            printf("%i, ", mat[i][j]);
            while (j > 0 && i < n-1) {    //end at left or bottom edge
                i++; j--;   //go down and left
                printf("%i, ", mat[i][j]);
            }
        }
        
        if (i > 0 && i < n-1 && j == m-1) {    //right edge and not top or bottom ends
            i++;    //go down once
            printf("%i, ", mat[i][j]);
            while (j > 0 && i < n-1) {    //end at left or bottom edge
                i++; j--;    //go down and left
                printf("%i, ", mat[i][j]);
            }
            //bottom-right end of matrix
            if (i == n-1 && j == m-1) {
                i++; j++;    //increase i and j to stop the big while-loop
            }
        }
        
        if (j > 0 && j < m-1 && i == n-1) {    //bottom edge and not left or right ends
            j++;    //go right once
            printf("%i, ", mat[i][j]);
            while (i > 0 && j < m-1) {    //end at top or right edge
                i--; j++;    //go right and up
                printf("%i, ", mat[i][j]);
            }
            //bottom-right end of matrix
            if (i == n-1 && j == m-1) {
                i++; j++;    //increase i and j to stop the big while-loop
            }
        }    
    }
    printf("\n");
}

int main(int argc, char **argv) 
{
/*
    int n=3, m=3;
    int mat[3][3] = {{1,  2,  3}, 
                     {4,  5,  6},
                     {7,  8,  9}};
                     
    zigZagMatrix(mat, n, m);
*/
/*
    int n2=4, m2=5;
    int mat2[4][5] = {{1,  2,  3,  4,  5}, 
                      {6,  7,  8,  9,  10},
                      {11, 12, 13, 14, 15},
                      {16, 17, 18, 19, 20}};
      
    zigZagMatrix(mat2, n2, m2);
*/
    return 0;
}

Remove the first pair of the block comment markers (/* */). Make the first argument of the called function, "int mat[][3]". Run the program and the output should be:

    1, 2, 4, 7, 5, 3, 6, 8, 9, 

Put back the first pair of the block comment markers (/* */). Remove the second pair of the block comment markers (/* */). Make the first argument of the called function, "int mat[][5]". Run the program and the output should be:

1, 2, 6, 11, 7, 3, 4, 8, 12, 16, 17, 13, 9, 5, 10, 14, 18, 19, 15, 20,

The time complexity is actually O(2 n x m), with the first O(n x m) for populating the input matrix with all the elements, and the second O(n x m) for iterating over all the elements in the matrix in the called function. Since the coefficient (multiplicand of 2) is usually omitted, the time complexity is quoted as O(n x m).

The space complexity is O(n x m), for the input matrix, which is the same as the matrix in the called function (same reference).

Thanks for reading.





Related Links

More Related Links

Cousins

BACK NEXT

Comments


Note: You can use the Search Box above to find articles and discussions of interest.