Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Лабораторные_работы_1-7.doc
Скачиваний:
25
Добавлен:
16.11.2019
Размер:
2.11 Mб
Скачать

2Задание 2

Задание 2.1

Дано натуральное число N. Вычислить

Задание 2.2

Дано натуральное число N. Вычислить

Задание 2.3

Дано натуральное число N. Вычислить

Задание 2.4

Даны натуральные числа N, M. Вычислить

Задание 2.5

Дано натуральное число N>2. Вычислить

Задание 2.6

Дано натуральное число N. Вычислить

Задание 2.7

Дано натуральное число N. Вычислить

Задание 2.8

Дано натуральное число N и вещественное f. Вычислить

Задание 2.9

Дано натуральное число N. Вычислить

Задание 2.10

Дано натуральное число N. Вычислить

Задание 2.11

Дано натуральное число N. Вычислить

Задание 2.12

Дано натуральное число N. Вычислить

Задание 2.13

Дано натуральное число N. Вычислить

Задание 2.14

Дано натуральное число N. Вычислить

Задание 2.15

Дано натуральное число N. Вычислить

Содержание отчета

Отчет выполняется по выбору преподавателя либо в редакторе Word, либо в черновом варианте в лекционной тетради. Отчет должен содержать:

  1. Листинг программ на языке Си, решающих задачи в соответствии с вариантом (номером компьютера) задания;

  2. Блок-схему алгоритма программ (см. примеры и Приложение II и III);

  3. Пояснения по методу решения задач и выбору исходных данных для тестирования;

  4. Результаты тестирования программ.

При оформлении отчета следует пользоваться копированием листинга и результата тестирования в Word. Последний копируется с помощью комбинации клавиш ALT Prt Sc при условии активности консольного окна, что означает копирование графики окна в буфер обмена Windows. Затем окно вставляется в документ Word как любой другой объект.

Контрольные вопросы к лабораторной работе №3

  1. Изобразите в черновике блок-схему цикла с постусловием, с предусловием, с параметром.

  2. Может ли условие операторов цикла быть арифметическим выражением, например, x*x+1 ?

  3. Можно ли переменную цикла с параметром изменять внутри тела цикла?

  4. Как действуют операторы continue и break в теле цикла ?

  5. Что такое вложенный цикл ? Изобразите блок-схему вложенного цикла.

ЛАБОРАТОРНАЯ РАБОТА №4

одномерные массивы

КРАТКИЕ ТЕОРЕТИЧЕСКИЕ СВЕДЕНИЯ

3Одномерные массивы

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

float A[10]; //описание массива из 10 вещественных переменных

Обращение к конкретному элементу массива осуществляется через его номер. При этом следует запомнить, что элементы массивов нумеруются с нуля, поэтому последний элемент имеет номер на 1 меньший общего количества элементов в массиве:

A[0], A[1], A[2], …, A[9].

В программе это выглядит, например, так:

x = A[2]; //x присвоено значение 3-го по счету элемента массива A

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

Как и переменные, элементы массива могут быть инициализированы. Инициализирующие значения для массивов записываются в фигурных скобках. Значения элементам присваиваются по порядку. Если элементов в массиве больше, чем инициализаторов, элементы, для которых значения не указаны, обнуляются:

int b[5] = {3, 2, 1}; // b[0]=3, b[l]=2, b[2]=l, b[3]=0, b[4]=0

int a[5] = {0}; //обнуление всего массива

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

float a [10]; //размерность задана целой положительной константой

const int n = 10; // размерность задана с помощью именованной

int marks[n]; // константы

int b[] = {3, 2, 1}; // размерность массива равна трем

При обработке массивов удобно использовать операторы цикла. В следующем примере подсчитывается сумма элементов массива:

const int n = 10;

int i, sum;

int marks[n] = {3, 4, 5, 4, 4};

for (i = 0, sum = 0; i<n; i++)

sum += marks[i];

cout << RUS("Сумма элементов: ") << sum;

Аналогично выполняется ввод и вывод элементов массива, например, с помощью объектов cin и cout:

const int N=5;

int i,massiv[N]; //описание массива

cout<<RUS("Введите 5 целых чисел\n");

for(i=0;i<N;i++) cin>>massiv[i]; //ввод массива

for(i=0;i<N;i++) //вывод массива

cout<<"\n massiv["<<i<<"] = "<<massiv[i]; //вывод массива