KEMBAR78
C++ Array | PDF | Matrix (Mathematics) | Computing
0% found this document useful (0 votes)
21 views20 pages

C++ Array

Two-dimensional arrays allow data to be stored in a table format with rows and columns. They are declared with two indices, one for the row and one for the column. Elements can be accessed and manipulated using these indices. Two-dimensional arrays can be passed to functions by reference and retain their two-dimensional structure.

Uploaded by

20kylegarrick
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
21 views20 pages

C++ Array

Two-dimensional arrays allow data to be stored in a table format with rows and columns. They are declared with two indices, one for the row and one for the column. Elements can be accessed and manipulated using these indices. Two-dimensional arrays can be passed to functions by reference and retain their two-dimensional structure.

Uploaded by

20kylegarrick
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 20

Two- and Multidimensional Arrays

In the previous section, you learned how to use one-dimensional arrays to manipulate
data. If the data is provided in a list form, you can use one-dimensional arrays. However,
sometimes data is provided in a table form. For example, suppose that you want to track
the number of cars in a particular color that are in stock at a local dealership. The
dealership sells six types of cars in five different colors. Figure below shows sample data
C++ simplifies the processing of manipulating data in a table form with the use of two-dimensional arrays.

Two-dimensional array: A collection


of a fixed number of components arranged in rows
and columns (that is, in two dimensions), wherein all components are of the same type.
The syntax for declaring a two-dimensional array is:

The statement:
double sales[10][5];
declares a two-dimensional array sales of 10 rows and 5 columns, in which every
component is of type double. As in the case of a one-dimensional array, the rows are
numbered 0. . .9 and the columns are numbered 0. . .4
Accessing Array Components
To access the components of a two-dimensional array, you need a pair of indices: one for
the row position and one for the column position
The statement:
sales[5][3] = 25.75;
stores 25.75 into row number 5 and
column number 3 (that is, the sixth
row and the
fourth column) of the array sales
Two-Dimensional Array Initialization During Declaration
Like one-dimensional arrays, two-dimensional arrays can be initialized when they are declared.
The following example helps illustrate this concept. Consider the following statement:
int board[4][3] = {{2, 3, 1},
{15, 25, 13},
{20, 4, 7},
{11, 18, 14}};
This statement declares board to be a two-dimensional array of four rows and three
columns. The components of the first row are 2, 3, and 1; the components of the second row
are 15, 25, and 13; the components of the third row are 20, 4, and 7; and the components of
the fourth row are 11, 18, and 14, respectively.
To initialize a two-dimensional array when it is declared:
1. The elements of each row are enclosed within curly braces and separated
by commas.
2. All rows are enclosed within curly braces.
3. For number arrays, if all components of a row are not specified, the
unspecified components are initialized to 0. In this case, at least one of
the values must be given to initialize all the components of a row.
Two-Dimensional Arrays and Enumeration Types

These statements define the carType and colorType enumeration types and define
inStock as a two-dimensional array of six rows and five columns. Suppose that each
row in inStock corresponds to a car type, and each column in inStock corresponds to
a color type. That is, the first row corresponds to the car type GM, the second row
corresponds to the car type FORD, and so on. Similarly, the first column corresponds to
the color type RED, the second column corresponds to the color type BROWN, and so on.
The statement:
inStock[1][3] = 15;
is equivalent to the following statement :
inStock[FORD][WHITE] = 15;

The second statement easily conveys the


message—that is, set the number of WHITE
FORD cars to 15. This example illustrates that
enumeration types can be used effectively
to make the program readable and easy to
manage.
Because the components of a two-dimensional array are of the same type, the
components of any row or column are of the same type. This means that each row and
each column of a two-dimensional array is a one-dimensional array. Therefore, when
processing a particular row or column of a two-dimensional array, we use algorithms
similar to those that process one-dimensional arrays.
Suppose that we want to process row number 5 of matrix (that is, the sixth row of
matrix). The components of row number 5 of matrix are:
matrix[5][0], matrix[5][1], matrix[5][2], matrix[5][3], matrix[5][4], matrix[5][5]

We see that in these components, the first index (the row position) is fixed at 5. The
second index (the column position) ranges from 0 to 5. Therefore, we can use the
following for loop to process row number 5:
for (col = 0; col < NUMBER_OF_COLUMNS; col++)
process matrix[5][col]

Similarly, suppose that we want to process column number 2 of matrix, that is, the third
column of matrix. The components of this column are:
matrix[0][2], matrix[1][2], matrix[2][2], matrix[3][2], matrix[4][2], matrix[5][2], matrix[6][2]
Initialization
Suppose that you want to initialize row number 4, that is, the fifth row, to 0. As
explained earlier, the following for loop does this:
row = 4;
for (col = 0; col < NUMBER_OF_COLUMNS; col++)
matrix[row][col] = 0;
If you want to initialize the entire matrix to 0, you can also put the first index, that is,
the row position, in a loop. By using the following nested for loops, we can initialize
each component of matrix to 0
for (row = 0; row < NUMBER_OF_ROWS; row++)
for (col = 0; col < NUMBER_OF_COLUMNS; col++)
matrix[row][col] = 0;
Print
By using a nested for loop, you can output the components of matrix. The following
nested for loops print the components of matrix, one row per line:
for (row = 0; row < NUMBER_OF_ROWS; row++)
{
for (col = 0; col < NUMBER_OF_COLUMNS; col++)
cout << setw(5) << matrix[row][col] << " ";
cout << endl;
}

Input
The following for loop inputs the data into row number 4, that is, the fifth row of matrix:
row = 4;
for (col = 0; col < NUMBER_OF_COLUMNS; col++)
cin >> matrix[row][col];
As before, by putting the row number in a loop, you can input data into each component
of matrix. The following for loop inputs data into each component of matrix:
for (row = 0; row < NUMBER_OF_ROWS; row++)
for (col = 0; col < NUMBER_OF_COLUMNS; col++)
cin >> matrix[row][col];
Sum by Row
The following for loop finds the sum of row number 4 of matrix; that is, it adds the
components of row number 4.
sum = 0;
row = 4;
for (col = 0; col < NUMBER_OF_COLUMNS; col++)
sum = sum + matrix[row][col];
Once again, by putting the row number in a loop, we can find the sum of each row
separately. Following is the C++ code to find the sum of each individual row:
//Sum of each individual row
for (row = 0; row < NUMBER_OF_ROWS; row++)
{
sum = 0;
for (col = 0; col < NUMBER_OF_COLUMNS; col++)
sum = sum + matrix[row][col];
cout << "Sum of row " << row + 1 << " = " << sum << endl;
}
Sum by Column
As in the case of sum by row, the following nested for loop finds the sum of
each individual column:
//Sum of each individual column
for (col = 0; col < NUMBER_OF_COLUMNS; col++)
{
sum = 0;
for (row = 0; row < NUMBER_OF_ROWS; row++)
sum = sum + matrix[row][col];
cout << "Sum of column " << col + 1 << " = " << sum << endl;
}

Largest Element in Each Row and Each Column

The following for loop determines the largest element in row number 4:
row = 4;
largest = matrix[row][0]; //Assume that the first element of the row is the largest.
for (col = 1; col < NUMBER_OF_COLUMNS; col++)
if (largest < matrix[row][col])
largest = matrix[row][col];
The following C++ code determines the largest element in each row and
each column:
//Largest element in each row
for (row = 0; row < NUMBER_OF_ROWS; row++)
{
largest = matrix[row][0]; //Assume that the first element of the row is the largest.
for (col = 1; col < NUMBER_OF_COLUMNS; col++)
if (largest < matrix[row][col])
largest = matrix[row][col];
cout << "The largest element in row " << row + 1 << " = “ << largest << endl;
}
//Largest element in each column
for (col = 0; col < NUMBER_OF_COLUMNS; col++)
{
largest = matrix[0][col]; //Assume that the first element of the column is the largest.
for (row = 1; row < NUMBER_OF_ROWS; row++)
if (largest < matrix[row][col])
largest = matrix[row][col];
cout << "The largest element in column " << col + 1 << " = " << largest << endl;
}
Passing Two-Dimensional Arrays as Parameters to Functions
Two-dimensional arrays can be passed as parameters to a function, and they are passed by reference..
When storing a two-dimensional array in the computer’s memory, C++ uses the row order form. That is, the
first row is stored first, followed by the second row, followed by the third row, and so on.
In the case of a one-dimensional array, when declaring it as a formal parameter, we usually omit the size of
the array. Because C++ stores two-dimensional arrays in row order form, to compute the address of a
component correctly, the compiler must know where one row ends and the next row begins. Thus, when
declaring a two-dimensional array as a formal parameter, you can omit the size of the first dimension, but
not the second; that is, you must specify the number of columns.

Suppose we have the following declaration:


const int NUMBER_OF_ROWS = 6;
const int NUMBER_OF_COLUMNS = 5;
Consider the following definition of the function printMatrix:
void printMatrix(int matrix[][NUMBER_OF_COLUMNS],
int noOfRows)
{
int row, col;
for (row = 0; row < noOfRows; row++)
{
for (col = 0; col < NUMBER_OF_COLUMNS; col++)
cout << setw(5) << matrix[row][col] << " ";
cout << endl; } }
Similarly, the following function outputs the sum of the elements of each row of a
twodimensional array whose elements are of type int.
void sumRows(int matrix[][NUMBER_OF_COLUMNS], int noOfRows)
{
int row, col;
int sum;
//Sum of each individual row
for (row = 0; row < noOfRows; row++)

{
sum = 0;
for (col = 0; col < NUMBER_OF_COLUMNS; col++)
sum = sum + matrix[row][col];
cout << "Sum of row " << (row + 1) << " = " << sum
<< endl;
}
}
The following program illustrates how two-dimensional arrays are passed as parameters
to functions.
// Two-dimensional arrays as parameters to functions.
#include <iostream>
#include <iomanip>
using namespace std;
const int NUMBER_OF_ROWS = 6;
const int NUMBER_OF_COLUMNS = 5;
void printMatrix(int matrix[][NUMBER_OF_COLUMNS],int NUMBER_OF_ROWS);
void sumRows(int matrix[][NUMBER_OF_COLUMNS],int NUMBER_OF_ROWS);
int main()
{
int board[NUMBER_OF_ROWS][NUMBER_OF_COLUMNS] = {{23, 5, 6, 15, 18}, {4, 16, 24, 67, 10}, {12, 54, 23, 76, 11},
{1, 12, 34, 22, 8}, {81, 54, 32, 67, 33}, {12, 34, 76, 78, 9}};

printMatrix(board, NUMBER_OF_ROWS);
cout << endl;
sumRows(board, NUMBER_OF_ROWS);
cout << endl;
return 0;
}

Place the definitions of the functions printMatrix and sumRows,


Arrays of Strings
Suppose that you need to perform an operation, such as alphabetizing a list of names. Because
every name is a string, a convenient way to store the list of names is to use an array. Strings in
C++ can be manipulated using either the data type string or character arrays (C-strings).

Arrays of Strings and the string Type


Processing a list of strings using the data type string is straightforward. Suppose that the list consists of a
maximum of 100 names. You can declare an array of 100 components of type string as follows:
string list[100];
Basic operations, such as assignment, comparison, and input/output, can be performed on values of the
string type. Therefore, the data in list can be processed just like any one-dimensional array.

Arrays of Strings and C-Strings (Character Arrays)


Suppose that the largest string (for example, name) in your list is 15 characters long and your list has 100
strings. You can declare a two-dimensional array of characters of 100 rows and 16 columns as follows :
char list[100][16];

Now list[j] for each j, 0 <= j <= 99, is a string of at most 15 characters in length. The following statement stores
"Snow White" in list[1]
strcpy(list[1], "Snow White");
Suppose that you want to read and store data in list and that there is one entry per line.
The following for loop accomplishes this task:
for (j = 0; j < 100; j++)
cin.get(list[j], 16);
The following for loop outputs the string in each row:
for (j = 0; j < 100; j++)
cout << list[j] << endl;
You can also use other string functions (such as strcmp and strlen) and for loops to
manipulate list.

You might also like