9.10 Print a matrix in spiral form, 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 mat[][] of size n x m, the task is to print all elements of the matrix in spiral form, as shown in the following figure:
Employ boundary traversal technique.
Example:
Input: mat[][] = {{1, 2, 3, 4, 5},
{14, 15, 16, 17, 6},
{13, 20, 19, 18, 7},
{12, 11, 10, 9, 8}};
The input numbers have been given in spiral form, and should just be read.
Output : 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20
Solution
The algorithm is as follows:
- Traverse the top row from j=0 to j=m-2.
- Traverse the rightmost column from i=0 to i=n-2.
- Traverse the bottom row from j=m-1 to j=1.
- Traverse the leftmost column from i=n-1 to i=1.
- Traverse the second row from j=2 to j=m-3.
- Traverse the last-but-one rightmost column from i=1 to i=n-3.
- Traverse the last-but-one bottom row from j=m-2 to j=2.
- Traverse the second leftmost column from i=n-2 to i=2.
- Traverse the third row from j=3 to j=m-4.
- Continue the traversing in the spiral form. - - -
- - - - - -
The program
The program is (read through the code and comments):
#include <stdio.h>
void spirallyTraverse(int mat[][5], int n, int m) {
//Let a be the difference between the row being traversed, and i=0.
//Let b be the difference between the column being traversed, and j=0.
int a = 0;
int b = 0;
//Let c be the difference between the bottom of the matrix and the traversing column end element index.
//Let d be the difference between the right end of the matrix and the traversing row end element index.
int c = 1;
int d = 1;
int totalNumOfElements = n * m;
int counter = 0;
int i=0, j=0;
while (counter < totalNumOfElements) {
// Traverse top current row from left to right
for (j=j+b; j < m-d; j++) {
printf("%i, ", mat[i+b][j]);
counter++;
}
// Traverse last current column from top to bottom
for (i=i+a; i < n-c; i++) {
printf("%i, ", mat[i][j]);
counter++;
}
// Traverse current bottom row from right to left
if (n > 1) { // Check to avoid duplicating row in single-row matrix
for (j = m - d; j > b; j--) {
printf("%i, ", mat[n-c][j]);
counter++;
}
}
// Traverse current first column from bottom to top
if (m > 1) { // Check to avoid duplicating column in single-column matrix
for (i = n - c; i > a; i--) {
printf("%i, ", mat[i][j]);
counter++;
}
}
a++; b++; c++; d++;
}
printf("\n");
}
int main(int argc, char **argv)
{
int n=4, m=5;
int mat[4][5] = {{1, 2, 3, 4, 5},
{14, 15, 16, 17, 6},
{13, 20, 19, 18, 7},
{12, 11, 10, 9, 8}};
spirallyTraverse(mat, n, m);
return 0;
}
The output is:
1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 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 LinksCousins
BACK NEXTComments
Note: You can use the Search Box above to find articles and discussions of interest.