int array[10][30];
Фактически двухмерный массив представляется как одномерный, элементы которого тоже массивы. Константное выражение, определяющее одну из размерностей массива, не может принимать нулевое значение:
int mas[0][7]; // ошибка
int mas[l][7]; // правильно
Можно инициализировать и многомерные массивы. Причем инициализация происходит построчно, т. е. в порядке возрастания самого правого индекса. Именно в таком порядке элементы многомерных массивов располагаются в памяти компьютера. Для примера рассмотрим, как будет выполнена инициализация трехмерного массива с восемью элементами:
int array[2][2][2]={23, 54, 16, 43, 82, 12, 9, 75}; Проинициализированный массив будет выглядеть так:
[0][0][0]= =23;
[0][0][1]= =54;
[0][1][0]= =16;
……..
[1][1][0]= =9;
[1][1][1]= =75;
Для наглядности при инициализации двухмерного массива список начальных значений следует оформлять в виде таблицы: int array[3][3]={ 34, 23, 67, 38, 56, 73, 37,94,28};
Многомерные массивы могут инициализироваться и без указания одной (самой левой) из размерностей массива. В этом случае количество элементов компилятор определяет по количеству членов в списке инициализации. Например, для массива array будет получен тот же, что и в предыдущем примере результат:
int array[][3]={ 34, 23, 67, 38, 56, 73, 37,94,28};
Если необходимо проинициализировать не все элементы строки, а только несколько первых элементов, то в списке инициализации можно использовать фигурные скобки, охватывающие значения для этой строки. Например, если необходимо для массива array задать начальные значения для элементов array[0][0], array[l][0], array[l][l], array[2][0], array[2][l], array[2][2], то это можно сделать следующим образом:
int array[][3]={{0}, {Ю,П}, {21,21,22}};
Особых отличий работы с многомерными массивами от одномерных нет, для доступа к элементу многомерного массива необходимо указать все его индексы:
tmp = array[l][2];
Здесь переменной tmp присваивается значение третьего элемента второй строки.
Пример на языке С. Транспонировать матрицу (на том же месте), используя оператор do ... while.
#include <iostream.h>
void main()
{
int mat[20][20]; // матрица целых чисел, максимум 20*20 ]
int size, i, j, temp;
do{
coun<<"\n\nВведите размерность матрицы: ";
cin>>size;
} while( size > 20 );
for (i=0; i < size; i++ )
{
coun<<"\пВведите строку номер : "«i+1;
for(j=0; j <size; j++ )
cin>>mat[i][j];
}
// само транспонирование i=1;
do{
j=0;
do{
temp = mat[i][j]; mat[i][j] = mat[j][i]; mat[j++][i ] = temp;
} while (j < i);
} while ( ++i < size );
// вывод результата
for ( i=0; i < size; i++ )
{ cout<<"\n\n";
for( j=0; j < size; j++ )
cout<< mat[i][j];
}
}
В настоящее время разработано большое количество языков программирования. Их условно можно разделить па следующие группы: машинно-ориентированные (Assembler): процедурно-ориентированные (Соbо1, Раsса1, Fortran, С); объектно-ориентированные (С#, C++, Delphi, Java); языки логических программ: языки решения интеллектуальных задач: языки описания сценариев. Assembler используется при разработке системных программ, так как позволяет эффективно учитывать специфику компьютера (драйвера, программы защиты и т. д.). Одной инструкции языка ассемблера в большинстве случаев соответствует одна машинная команда. Раsса1, С, Fortran, PLM языки высокого уровня. Один оператор алгоритмического языка преобразуется в целую совокупность машинных команд. Си используется при разработке системных программ. Для решения экономических задач используется Соbо1. Для решения интеллектуальных задач - Lisp, Ргоlоg, Smalltalk. Языки описания сценариев (Регl, Rехх, Visual Basic) и языки оболочек UNIX, предполагают стиль программирования, отличный от характерного для языков системного уровня. Они предназначаются не для написания приложений с нуля, а для комбинирования компонентов, набор которых создается заранее при помощи других языков.
Оператор присваивания должен быть только там, где есть переменные, однако все языки содержат этот оператор или конструкцию, выполняющую аналогичные функции. If then else условный оператор в том или ином виде необходим в каждом языке программирования. Elsef. Для удобства записи нескольких равнозначных вариантов необходимо, чтобы условный оператор позволял использовать несколько elsif. Цикл с предусловием while выполняется, пока условие истинно. Цикл с параметром for выполняется, пока параметр не превысит конечное значение. Массивов в большинстве новых языков как самостоятельной конструкции нет, вместо них используются списки. Однако в нефункциональных языках можно получить доступ к элементу списка по его номеру, например «k[5]». В этом случае языку начислялся балл за массивы. Массивы из элементов разного типа в традиционных языках называются структурами (С) или записями (Паскаль). В новых языках роль структур, как правило, выполняют классы или списки. В традиционных языках обычно имеется возможность создавать структуры с вариантной частью (когда общая память выделяется под разные наборы полей).. Булевский (логический) тип присутствует во всех языках программирования. В данном случае оценивалось наличие специальных констант «true» и «false». Использование вместо них целочисленных значений 0 и 1 часто приводит к трудно обнаруживаемым ошибкам (в частности, к неверному преобразованию типов в условных выражениях); Поскольку программисты издавна используют отступ (пустые пробелы в начале строки) для улучшения читабельности программ, было бы глупо не воспользоваться этим для определения конца блочного оператора. Однако в обзоре такой механизм имеют только два языка из шести.
Список использованной литературы
1 Демичев Е.М. Основы программирования, 2005
2 Стивен Прата. Язык программирования С, 2006
3 Мильвидский А. М. Введение в Java., 1998
4 М.Плискин Эволюция языков программирования, 2002
5 Мясников В.А., Майоров С.А. ЭВМ для всех., 1985
Б
библиотека..................... 14
В
вариант......... 13, 14, 16, 33
выражение 8, 16, 17, 18, 19, 20, 21, 25, 26, 27, 29
К
константа........ 8, 19, 20, 25
М
массив 3, 4, 25, 26, 27, 28, 29, 30, 34
матрица..................... 29, 31
О
оператор 3, 7, 9, 16, 17, 18, 19, 20, 21, 22, 23, 26, 27, 31, 33
П
пример 3, 4, 13, 26, 27, 28, 29, 31
программа 2, 3, 5, 7, 8, 9, 10, 11, 12, 13, 14, 16, 17, 20, 23, 28, 33
С
стиль..................... 7, 10, 33
Ф
функция...... 8, 9, 10, 17, 33
Э
элемент 8, 9, 25, 26, 27, 29, 30, 34
Я
язык 1, 2, 5, 6, 7, 8, 9, 10, 12, 13, 14, 16, 22, 23, 33, 34