Table of Contents
Two-dimensional arrays have rows and columns, storing data inside this matrix.
These 2D matrices cannot be passed directly to functions like single-dimension arrays. The program needs to follow some required rules.
Ways to Pass a 2D Array to function in C++
This article explains the various method to pass a 2D matrix to a method in C++.
Pass a 2D Array to a Function by Passing Its Pointer
By using a pointer, an array can be passed to the function if it has a variable size and if the size is known during the compile time.
Note: The first two programs deal with an array of varied sizes, which means the scope of these arrays is localized and needs to be declared more than once and the compiler has to check them for dimension mismatch.
The last program deals with an array of fixed sizes. These are declared only once in the program, eliminating the risk of dimension checks.
Let’s create a program that passes the array by passing its pointer.
- 
Import package iostreamand definenamespaceas std.
- 
In this program, a function funcis created having a single parameter –int(*array)[3][3]which is a pointer to a two-dimensional array having three rows and three columns each.123void func(int(*array)[3][3])
Note: An array is not a pointer, thus declaring it needs a little know-how for the programmer. The below ASCII diagram explains how the compiler differentiates between index and pointers.

The pointer to the entire array points to an array of six integers(depicted as a large box), whereas the pointer to the first element only points to a single integer (seen as a little box).
Despite being completely different types, a pointer to an object and a pointer to its first data member has the same value (the same location).
The parenthesis in the type int(*)[8] are vital if you are unfamiliar with the C declarator syntax:
- A pointer to an array of 6 elements is denoted by – int(*array)[6].
- 6 pointers of the type int*making up the array are denoted by –int* array[6].
- 
Inside the method, the contents of the array are printed using a for loop inside a while loop. The whileloop iterates three times and for each iteration ofi, the for loop iterates three times.1234567891011size_t i=0;while(i<3){cout << i << ": ";for (size_t j = 0; j < 3; ++j)cout << (*array)[i][j] << '\t';cout << std::endl;++i;}
- 
Inside the main function, a two-dimensional array is created with the same dimension as the one in the funcmethod. Then the array is initialized with key pair values.
- 
Lastly, the method is called by passing the pointer of the array to the method func().
When all of the array's dimensions are fixed and known at compile time, use this approach because the compiler flags dimensions in events of mismatch.
Complete code given below:
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 | #include <iostream> using namespace std; void func(int(*array)[3][3]) {     // Printing the array     size_t i=0;     while(i<3)     {         cout << i << ": ";         for (size_t j = 0; j < 3; ++j)             cout << (*array)[i][j] << '\t';         cout << std::endl;         ++i;     } } int main() {     int a[3][3] = { {2,1,1},{3,3} };     func(&a); } | 
Output:
| 1 2 3 4 5 | 0: 2    1       1 1: 3    3       0 2: 0    0       0 | 
We have seen how the passing pointer of the array can pass an array to a function. In the next section, we will directly pass an array using a concept called decayed array pointers.
Pass an Array to the Function by Decaying the Pointer to the Array
Before venturing toward the program, let's first understand what is a decaying pointer.
An array type is represented as T[n], where T represents the element type and n represents the array's positive size, or the total number of elements, like:
| 1 2 3 | int array[10]; // int is Type of array and 10 is the size | 
The element type and size are products of the array type. Since the size is a component of the type, array types with different sizes are incompatible and unrelated to one another.
sizeof(T[n]) is equivalent to n * sizeof(T)
An array-like – int arr[5] represented in an ASCII diagram looks like this:

Suppose two arrays T[m] and T[n] are created. The only "connection" between T[n] and T[m] is that both types can implicitly be transformed to T*, with the result being a pointer to the array's first element.
In other words, you can use a T[n] whenever a T* is needed, and the compiler will quietly provide that pointer.
This conversion, referred to as "array-to-pointer decay," removes the value inside the first index of the array, which stores the address. Since the array's size is no longer a component of the type (T*), it is lost during this procedure.
Decaying a pointer is useful when the programmer forgets the dimension and can decay it to point to its first element, but at the same time, its size is lost in the process.
This way an array can be directly passed to the function without the need to pass its address but doing so will force the compiler to decay it into a pointer and delete its 0th index. To combat it, we need to pass the number of rows as a separate argument.
Let's create a program that decays the array to pass its information.
- 
Import library package iostreamand define thenamspaceasstd.
- 
A function func_decay_pointeris created which has two parameters – a single pointer integer arrayarrof size –4and another variablerowsof type –size_t.The reason to use a separate variable for rows instead of using a 2D array is that the compiler will decay the first index when this array will get passed. To avoid losing size, we store the size of rows separately. The declaration int(*arr)[4]can also be written asint array[][4]. Using the latter statement is legal but can confuse programmers as some may take it as a two-dimensional array whereas it is still a single-pointer integer array having 4 elements.This method provides some safety as passing an incorrect value of rows will cause the compiler to flag the values. 
- 
Inside the method, the method name and the contents of the array are printed. Two nested for loops print the contents, where the first loop iterates up to the value of variable rowsand the second loop iterates for the number of columns.
- 
Inside the main function, a two-dimensional array arr1is created and initialized with some key pair values.
- 
Lastly, the function func_decay_pointeris called by passing the array and the value ofrowas an argument.
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 | #include <iostream> using namespace std; void func_decay_pointer(int(*arr)[4], size_t rows) {     cout << __func__ << endl;     for (size_t i = 0; i < rows; ++i)     {         cout << i << ": ";         for (size_t j = 0; j < 4; ++j)             cout << arr[i][j] << '\t';         cout << endl;     } } int main() {     int arr1[3][4] = { {6,5,9,6 }, {6,4,8,1 }, {3,5,7} };     func_decay_pointer(arr1, 3); // Value of row is passed as an argument along with the array                               // as its 1st index gets decayed } | 
Output:
| 1 2 3 4 5 6 | func_decay_pointer 0: 6    5       9       6 1: 6    4       8       1 2: 3    5       7       0 | 
Further reading:
Pass a 2D Array to a Function in C++ Without Size by Passing Its Reference
This is the safest method to pass an array to a function but limits the flexibility of the operation. Having no size(fixed size) eliminates the risk of dimension mismatch and the dimensions are provided right at the compile time.
This program uses two individual variables for rows and columns of the 2D array and then uses those variables for the size of the array. The program does not lose its dimension because the reference of the array gets passed to the method.
The size of the array remains fixed throughout the program unlike the dynamic arrays, and thus does not requires the compiler to check for dimension mismatch.
Let's create a program that passes the array to its method by passing the reference.
- Two individual variables rowandcolumnof datatype –size_tare created inside a template.
- A method func_passby_refrnceis created having a dereferenced integer array&arrayas a single parameter withrowandcolumnas its dimensions.
- The name of the method and the contents of the array are printed using nested for loops, simmilar to what we did in previous program.
- Inside the main program, a two dimensional array of size [5][5] is created, and it's dimensions are initialized.
- Lastly, this array is passed to the function.
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 | #include <iostream> template <size_t row, size_t column> void func_passby_refrnce(int(&array)[row][column]) {     std::cout << __func__ << std::endl;     for (size_t i = 0; i < row; ++i)     {         std::cout << i << ": ";         for (size_t j = 0; j < column; ++j)             std::cout << array[i][j] << '\t';         std::cout << std::endl;     } } int main() {     int arr[5][5] = { {6,5,9,6 }, {6,4,8,1 }, {3,5,7} };     func_passby_refrnce(arr); } | 
Output:
| 1 2 3 4 5 6 7 8 | func_passby_refrnce 0: 6    5       9       6       0 1: 6    4       8       1       0 2: 3    5       7       0       0 3: 0    0       0       0       0 4: 0    0       0       0       0 | 
Conclusion
This article explains how to pass two dimensional array to a function using three different method. The reader after going through this article will easily create programs that pass two dimensional arrays to its methods.
It is hoped that this article helped in your learning journey.

