Главная » Статьи » Програмування » C [ Добавить статью ]

RUS Уроки по программированию на языке С (Двумерные массивы, как частный случай многомерных массивов.)

Двумерные массивы, как частный случай многомерных массивов.

Мы с вами уже имеем понятие о том, что такое массивы, в прошлом уроке мы разобрали так называемый - одномерный массив. Одномерный массив - массив данных, где каждое значение обладает только одной характеристикой - порядковым номером (индексом). Именно по этому индексу мы и обращаемся к конкретному элементу.

Сегодня мы поговорим о многомерных массивах, т. е. о массивах, где каждый элемент описывается несколькими характеристиками. Примером значения многомерного массива может являться, что угодно: 

1. Шахматная доска - каждая клетка имеет две размерности E2 (буква и цифра)

2. Оценка КВН - три размерности ЧЛЕН_ЖЮРИ, КОНКУРС, КОМАНДА.

Максимальная размерность массива допустимая в С - . Мы с вами остановимся на двумерном массиве, второе название которого матрица.

Двумерный массив.

Объявление и расположение в памяти.

Двумерный массив представляет собой совокупность строк и столбцов, на пересечении которых находится конкретное значение. Объявить двумерный массив несложно, необходимо указать количество строк и столбцов. При этом, здесь действуют все теже правила, что и при объявлении одномерного массива. Т. е. нельзя в качестве количества строк и столбцов указывать неконстантные и  нецелочисленные значения.

Общий синтаксис:

 тип_данных имя_массива [число_строк][число_столбцов];

Пример:
 const int row=3; // строки
 const int col=4; // столбцы
 int array[row][col]; // массив размером row на col(3х4)

Несмотря на то, что мы представляем массив в виде матрицы, на самом деле - любой двумерный массив располагается в памяти построчно: сначала нулевая строка, затем первая и так далее. Об этом следует помнить, т. к. выход за пределы массива может повлечь за собой некорректную работу программы, при этом не выдав ошибки.

Инициализация.

Инициализация двумерного массива также аналогична инициализации одномерного:

1. Инициализация при создании.

Каждая строка заключается в отдельные фигурные скобки:

 int array[2][2]={{1,2},{7,8}};

Значения указываются подряд и построчно вписываются в массив:

 int array[2][2]={7,8,10,3};

Если значение пропущенно, оно будет инициализированно нулем:

 int array[3][3]={{7,8},{10,3,5}};

2. Инициализация c помощью цикла.

Откроем один секрет - двумерный массив можно рассматривать как совокупность, не просто строк, а одномерных массивов. То есть, один одномерный массив, мы заполняем простым циклом, перебирая конкретные элементы, а при совокупности, нам необходимо перебирать еще и отдельные массивы.

#include<iostream>
#include<stdlib.h> // в этом файле содержатся функции rand и srand
#include<time.h> // в этом файле содержится функция time
using namespace std;
void main()
{

 const int row=3; // строки
 const int col=3; // столбцы
 int mr[row][col]; // массив размером row на col

 // перебираем отдельные строки (одномерные массивы в совокупности)
 for(int i=0; i<row; i++)
 {
 // перебираем отдельные элементы каждой строки
 for(int j=0; j<col;j++)
 {
 // инициализация элементов значениями в диапазоне от 0 до 100
 mr[i][j]=rand()%100;
 
 // показ значений на экран
 cout<<mr[i][j]<<" ";
 }
 
 // переход на другую строку матрицы
 cout<<"\n\n";
 }

}
Примечание: Обращение к конкретному элементу массива производится по номеру строки и номеру столбца, например - mr[2][1] - значение, лежащее на пересечении второй строки и первого столбца.

Практический пример.

Постановка задачи.

Написать программу, которая в двумерном массиве находит максимальный элемент каждой строки.

Код реализации.
#include<iostream>
#include<stdlib.h> // в этом файле содержатся функции rand и srand
#include<time.h> // в этом файле содержится функция time

using namespace std;

void main()
{
 // задаем размерность массива
 const int m = 3;
 const int n = 2;
 int A[m][n]; // объявляем двумерный массив
 
 // заполнение массива случайными числами и показ на экран
 
 // перебираем отдельные строки (одномерные массивы в совокупности)
 for(int i=0; i<m; i++)
 {
 // перебираем отдельные элементы каждой строки
 for(int j=0; j<n;j++)
 {
 // инициализация элементов значениями в диапазоне от 0 до 100
 A[i][j]=rand()%100;
 
 // показ значений на экран
 cout<<A[i][j]<<" ";
 }
 
 // переход на другую строку матрицы
 cout<<"\n\n";
 }
 

 
 cout << "\n\n";

 // поиск в строках максимального элемента

 // перебираем отдельные строки (одномерные массивы в совокупности)
 for (int i=0; i<m; i++){

 // предполагаем, что максимальный - нулевой элемент строки 
 int max = A[i][0]; 

 // поиск максимального элемента в текущей строке

 // изменение индекса столбца для текущей строки
 for (int j=0; j<n; j++) 
 {
 if (A[i][j] > max)
 max = A[i][j];
 }
 cout << "Максимальный элемент " << i 
 << "-ой строки = " << max << endl;
 }
}

Обратите внимания!!!

1. На каждой итерации цикла в качестве максимума выбирается нулевой элемент текущей строки.

2. После анализа конкретной строки найденный максимум выводится на экран.


Категория: C | Добавил: DEN-SHP (05.11.2012)
Просмотров: 861 | Рейтинг: 0.0/0
Всего комментариев: 0
Добавлять комментарии могут только зарегистрированные пользователи.
[ Регистрация | Вход ]