ПРАКТИЧЕСКАЯ ЧАСТЬ. Пример 1. Написать программу заполнения одномерного массива случайными числами из интервала от 1 до 15 по случайному равномерному закону
Пример 1. Написать программу заполнения одномерного массива случайными числами из интервала от 1 до 15 по случайному равномерному закону. Отсортируйте массив случайных чисел по возрастанию. Для решения поставленной задачи применим сортировку методом прямого выбора [3]. Алгоритм сортировки заключается в следующем: 1) в исходной последовательности из N элементов отыскивается элемент с наименьшим ключом; 2) он меняется местами с первым элементом; 3) в оставшейся последовательности из (N – 1) элементов отыскивается минимальный элемент и меняется местами со вторым элементом и т. д., пока не останется один, самый большой элемент. Программный код решения примера
Рис. 5.1. Сортировка одномерного массива по возрастанию В программе использованы директивы препроцессора для задания левой границы (#define Left 1), правой границы (#define Right 15) и размера одномерного массива (#define N 10). Включены дополнительные библиотеки: time.h – для обращения к функциям системного времени, stdlib.h – для обращения к функциям генерации псевдослучайных чисел.
Задание 1 1. Границы формирования случайных чисел и размерность массива задайте без препроцессорных директив. 2. Произведите сортировку массива случайных чисел по убыванию. 3. Введите границы интервала формирования случайных чисел по правилу: Left = X, Right = 3X, где Х – номер компьютера (1, 2, ¼), на котором выполняется лабораторная работа. Произведите сортировку по убыванию. 4. Найдите и изучите сортировку методом прямого обмена (сортировка методом пузырька). Напишите программу формирования одномерного массива случайными числами и их сортировки методом пузырька. Пример 2. Написать программу поиска максимального элемента в заданном одномерном массиве. Элементы массива являются целыми числами. Программный код решения примера
В программе использована инициализация безразмерного массива и определения его размерности с помощью функции sizeof(). Рис. 5.2. Определение максимального элемента массива
Задание 2 1. В программе предусмотрите вывод на консоль значений массива в виде строки и определите индекс максимального элемента. 2. Определите минимальный элемент массива и его индекс. 3. Напишите программу перемещения максимального и минимального элементов на края массива. Например, максимальный элемент поместите в конец массива, а минимальный – в его начало. Выведите на консоль исходный массив данных и преобразованный массив в виде двух строк, следующих друг за другом. 4. Напишите программу ввода целых чисел массива с клавиатуры и определения максимального и минимального элементов в нем. Количество вводимых чисел задается по соотношению 5Х, где Х – номер компьютера, на котором выполняется лабораторная работа. Пример 3. Написать программу циклической перестановки чисел заданного массива так, чтобы i -e число стало (i + 1)-м, а последнее число – первым. Выведите на дисплей исходный массив и преобразованный. Программный код решения примера
Рис. 5.3. Пример циклической перестановки элементов числового массива Задание 3 1. Выведите на дисплей (для проверки) два элемента массива В, номера которых превышают размерность массива D. 2. Программным путем подсчитайте сумму элементов массива и выведите ее на консоль. 3. Дополните программу формированием массива, в котором элементы расположены в обратном порядке, чем в исходном массиве. 4. Сформируйте массив кодов строчных букв латинского алфавита. Выведите на дисплей сами буквы и их коды, которые являются элементами массива. Пример 4. В данном одномерном массиве вещественных чисел поменять местами элементы, стоящие на нечетных местах, с элементами, стоящими на четных местах. Предусмотреть четность и нечетность размерности массива. Для определения четности места в заданном массиве можно использовать операцию деления по модулю, т. е. %. Программный код решения примера
При инициализации массива каждый его элемент снабжен суффиксом F. Рис. 5.4. Смена четных и нечетных мест чисел массива Задание 4 1. Вывод на дисплей пользователя исходного массива и преобразованного выполните без дополнительного массива. 2. В программу внесите изменения, чтобы не использовать целочисленную переменную для определения остатка от деления. 3. Проверьте программу для массива с четным количеством элементов. 4. Напишите программу без использования операции определения остатка от деления, т. е. без использования операции i % 2. 5. Напишите программу для двухмерного массива вещественных чисел. Смену мест элементов (четных с нечетными) предусмотрите в каждой строке матрицы. Размер матрицы примите равным n × m, где n = 2X – количество строк, m = 3X – количество столбцов, Х – номер компьютера, на котором выполняется лабораторная работа. Указание. Можно предусмотреть определение остатка от деления, как индекса строки, так и индекса столбца и суммы индексов строки и столбца.
Пример 5. Написать программу заполнения квадратной матрицы (заданного размера n > 2) по спирали натуральными числами начиная с левого верхнего угла (принимая его за номер 1) и двигаясь по часовой стрелке.
Программный код решения примера
Рис. 5.5. Пример заполнения матрицы по спирали Задание 5 1. Дополните программу расчетом количества четных элементов выше главной диагонали матрицы и количества нечетных элементов ниже главной диагонали, не включая саму диагональ. 2. Протестируйте программу при изменении размера матрицы от 3 до 12. Результаты вставьте в отчет лабораторной работы. 3. Напишите программу заполнения матрицы по спирали против часовой стрелки, начиная с верхнего левого угла (номер 1). 4. Напишите программу с вводом направления заполнения матрицы. Например, если будет введено число 1, то заполнение выполните по часовой стрелке, если введено число –1 – против часовой стрелки. 5. Напишите программу заполнения прямоугольной матрицы натуральными числами «змейкой» построчно: слева – направо – справа – налево и т. д. Пример 6. Каждый день производятся замеры некоторых величин (вещественных значений), причем значения этих величин сводятся в прямоугольную таблицу размера n × m. Составить многомерный массив данных за 30 дней. Формирование данных произвести по случайному равномерному закону из интервала от –12 до 21. Этот пример относится к определению трехмерного массива данных. Программный код решения примера
В программе используется трехмерный массив размера 30 × 6 × 7. Это означает, что прямоугольная таблица (массив) данных размера 6 × 7 как бы скрепляется 30 раз – по заданному числу дней. Границы случайных чисел определены с помощью спецификатора const. Возможный результат выполнения программы представлен на рис. 5.6. Задание 6 1. В программе сделайте предварительное обнуление трехмерного массива. 2. Измените тип вещественных данных float на тип double. Проверьте работу программы. 3. Найдите максимальный и минимальный элементы массивов. 4. Найдите абсолютные значения максимального и минимального элементов всего трехмерного массива. 5. Выполните заполнение трехмерного массива размера 3 × 5 × 7 натуральными числами и выведите на консоль полученный многомерный массив. Пример 7. Написать программу по перемножению двух матриц А и В с размерностями (m × r) и (r × n) соответственно. Матрицу А принять размером 4 × 5, матрицу В – размером 5 × 3 (обе целочисленные). Условием перемножения двух матриц А и В является равенство числа столбцов матрицы А и числа строк матрицы В. В результате перемножения получим матрицу С размера m × n. Приведем схему по размерностям: C = AB = (m ´ r) (r ´ n) = m ´ n. Поэлементное перемножение двух матриц в стандартной математической форме имеет вид С учетом синтаксиса формирования массивов в языке С индексация должна начинаться с нуля, поэтому формулу перепишем в следующем виде: Программный код решения примера
В программе используются три цикла по формированию произведения двух матриц. Первый цикл (переменная i) связан с количеством строк первой матрицы (матрицы А), второй (переменная j) – с количеством столбцов второй матрицы (матрица В), третий (переменная k) – со смежной размерностью матриц, которая исчезает в результирующей матрице С. Матрицы А и В определены как неизменяемые типы (const int). Приведенный программный метод можно назвать первым методом – метод «ijk». Рис. 5.7. Результат произведения двух матриц Задание 7 1. Измените программу, чтобы циклы были организованы в порядке «jki». Это можно назвать вторым методом программного перемножения двух матриц. 2. Измените программу, чтобы циклы были организованы в порядке «kji». Это можно назвать третьим методом программного перемножения двух матриц. 3. Примените тип float для заданных матриц. Предусмотрите форматированный вывод результата на консоль, когда элементы столбцов выравниваются по правому краю, а между столбцами фиксированное число позиций (между числами с наибольшим количеством цифр).
Контрольные вопросы 1. Как организуются многомерные числовые массивы в языке С? 2. Как организуется индексирование числовых массивов в языке С? 3. На кого или на что возлагается контроль границ числовых массивов в языке программирования С? 4. В какой очередности и как происходит заполнение многомерных числовых массивов в программах на языке С? 5. Для чего применяется начальная инициализация числовых массивов при дальнейшем их использовании? 6. Сколько потребуется операторов цикла для вывода на консоль двухмерного числового массива (матрицы чисел)? 7. Почему при определении размерности массива с помощью препроцессорной директивы define не используется точка с запятой после числового значения?
|