Информатика и программирование (часть 1). Вариант №03
|
|
engineerklub | Дата: Вторник, 10.10.2023, 11:07 | Сообщение # 1 |
Генералиссимус
Группа: Администраторы
Сообщений: 28626
Статус: Online
| Информатика и программирование (часть 1). Вариант №03
Тип работы: Работа Контрольная Форматы файлов: Microsoft Word Сдано в учебном заведении: СибГУТИ
Описание: Вариант №03
1. Обработка одномерных массивов. Цель: изучение простейших алгоритмов организации и обработки одномерных массивов на языке С++.
Задание 1. Самостоятельно изучить возможности языка программирования C++ для описания, инициализации и обработки одномерных массивов. 2. Создать консольное приложение, в котором реализовать следующие вычисления: объявление заданного массива целых чисел фиксированной длины; инициализацию элементов массива посредством ввода с клавиатуры; заданный расчет и вывод его результата на консоль. обменную (пузырьковую) сортировку элементов массива заданного направления (нечетные варианты – по возрастанию, четные – по убыванию), реализовать в виде пользовательской функции int Sort(int Ar[]), которая принимает в качестве аргумента исходный массив, а возвращает количество перестановок; вывести на экран исходный и отсортированный массив, а также количество перестановок; вывод массивов реализовать в виде пользовательской функции void Output(int Ar[]). 3. Выполнить контрольную пошаговую обработку и сортировку массива из контрольного примера вручную.
Варианты индивидуальных заданий: № вар. Массив и длина Расчетный показатель 3 Y(7) Сумма положительных чётных элементов
Листинг программы Результаты выполнения программы
=============================================
2. Работа с матрицами Цель: освоение составления и тестирования алгоритмов и программ, реализующих основные операции по формированию и обработке двумерных числовых массивов – прямоугольных числовых матриц.
Задание
В соответствии с индивидуальным заданием заполнить матрицу размером 9х9 случайными целыми числами из заданного диапазона и выполнить заданное преобразование матрицы. Исходную и преобразованную матрицы вывести на экран.
Варианты индивидуальных заданий: № вар. Диапазон Преобразование матрицы 3 [-20, 10] Поменять местами строки с максимальной и минимальной суммой элементов
Листинг программы Результаты выполнения программы
------------------------------------------------------------------------------
3. Сложная обработка массивов.
Цель: изучение алгоритмов организации и сложной обработки массивов на языке С++.
Задание
1. В соответствии с индивидуальным заданием (табл. 1.2) записать в матрицу размером 9х9 линейную последовательность натуральных чисел (1, 2, 3, ...). результатную матрицу вывести на экран. 2. Заполнить матрицу размером 9х9 случайными числами из диапазона 0…99 и выполнить заданное (табл. 1.2) преобразование матрицы. Исходную и преобразованную матрицы вывести на экран.
№ вар. Задание на формирование матрицы Задание на преобразование матрицы Формирование Иллюстрация Преобразование Иллюстрация 3 Заполнить секторы матрицы, которые лежат выше и ниже главной и побочной диагоналей от левого верхнего угла вниз - вправо. Остаток матрицы заполнить нулями. Заполнить матрицу случайными числами. Разместить на главной диагонали суммы элементов, которые лежат на диагоналях, перпендикулярных к главной.
Листинг программы Результаты работы программы
СКАЧАТЬ
|
|
| |
engineerklub | Дата: Вторник, 10.10.2023, 11:08 | Сообщение # 2 |
Генералиссимус
Группа: Администраторы
Сообщений: 28626
Статус: Online
| 4. Обработка динамических массивов.
Цель: изучение и освоение использования динамически создаваемых массивов, а также программирование обработки динамических массивов на языке С++.
Задание
1. Изучить понятие динамической памяти и области её эффективного использования, а также возможности языка программирования С++ для управления динамическими переменными и создания динамических массивов. 2. Составить программу для ввода и обработки динамической матрицы целых чисел в соответствии с заданием 1 в табл. 2 посредством выделения памяти под одномерный массив целых чисел. 3. Составить программу для ввода и обработки динамической матрицы целых чисел в соответствии с заданием 2 в табл. 2 при помощи массива указателей. Размер матрицы вводить с клавиатуры. Элементы матрицы инициализировать случайными числами в произвольно выбранном диапазоне. 4. При выполнении заданий 1 и 2 из таблицы предусмотреть освобождение памяти после завершения обработки матрицы.
Варианты индивидуальных заданий № вар. Задание 1 Задание 2 3 В двумерном массиве Y определить и вывести на экран максимальный элемент массива Yмакс и его номер. Размерность массива задавать с клавиатуры, элементы массива заполнять с использованием генератора случайных чисел в диапазоне, задаваемом пользователем. Элементы столбцов, у которых среднее арифметическое значение отрицательно, разделить на эти средние значения. Листинг программы
Результаты работы программы
Результаты работы программы
СКАЧАТЬ
|
|
| |
engineerklub | Дата: Вторник, 10.10.2023, 11:09 | Сообщение # 3 |
Генералиссимус
Группа: Администраторы
Сообщений: 28626
Статус: Online
| Тип работы: Работа Лабораторная Форматы файлов: Microsoft Word Сдано в учебном заведении: СибГУТИ
Описание: Вариант №03
Лабораторная работа №1
Тема: Представление данных в ЭВМ и основы алгоритмизации Цель: изучение способов представления информации в памяти ЭВМ, освоение принципов цифрового кодирования информации в ЭВМ.
Задание
1. В приложении А выбрать исходные данные (ИД) согласно номеру своего варианта. 2. Представить десятичное число 1а в двоичной и шестнадцатеричной системе счисления в формате байт1. 3. Представить десятичные числа 1а, 1б и -1в в двоичной и шестнадцатеричной системе счисления в формате слова и двойного слова2. 4. Зашифровать данный текст 2, используя таблицу ASCII-кодов. 5. Расшифровать данный текст 3, используя таблицу ASCII-кодов. 6. Составить программу на языке С реализующую указанные в пп. 2 – 5 преобразования и выводящую их на дисплей. Коды выводить в формате dec и hex3. 7. Отладить программу и получить результаты. 8. Добавить в программу код для вычисления значения функции z (см. функцию преобразования 1 в приложении Б), приняв за x число А, а за y число В. Подтвердить расчет ручным просчетом. 9. Составить блок-схему линейного алгоритма для программы4. 10. Сделать выводы.
Примечания: 1. В задании 2 в число "1а" разряд сотен заменить нечетным вариантам на ноль, четным вариантам – на единицу. 2. В задании 3 "-1в" означает целую часть числа 1в со знаком "минус". 3. При программировании задания 5 необходимо использовать несколько инструкций (по количеству кодов) 4. При составлении блок-схемы использовать символы 1, 2, 7 и 8 согласно рис. 1.7. Вариант 3 1. а) 759(10); б) 265(10); в) 79. 2. Информатика. 3. 50 72 6F 63 65 64 75 72 65.
Номер варианта Функция преобразования 1 3 z=13-x-y/2
=============================================
Лабораторная работа №2
Тема: Разработка вычислительных программ с использованием стандартных функций и структурных операторов ветвления и цикла. Цель: изучение средств языка C по программированию алгоритмов с ветвлением и циклами с использованием стандартных математических функций. Задание
1. В соответствии с номером варианта разработать программу на языке С++ для вычисления значения функции y (см. функция преобразования 2 в приложении Б). При вводе исходных данных с клавиатуры и выводе результата работы программы использовать десятичную систему счисления в вещественном формате. Для проверки значения аргумента функции использовать оператор if. Проверить адекватность работы программы на контрольном примере.
3
2. В соответствии с индивидуальным заданием из приложения В разработать программу на языке C++ для вычисления и вывода на экран минимального (ymin) и максимального (ymax) значения функции y=f(x) при x[x1, x2] с шагом x, и номеров интервалов, на которых достигаются эти значения. Величины a и b ввести с клавиатуры. Использовать оператор цикла заданного вида. Обеспечить вывод на экран в табличной форме для каждого шага вычислений следующие промежуточные результаты: • номер шага; • текущее значение аргумента х; • текущее значение функции y; • текущее значение минимума функции ymin; • номер интервала nmin, соответствующие значению ymin; • текущее значение минимума функции ymax; • номер интервала nmax, соответствующие значению ymax; 3. Выполнить ручной просчет для значения аргумента из третьего интервала и сравнить его с результатами выполнения программы.
№ п/п Функция Y Интервал и шаг Заданный оператор цикла 3 x[0,8; 2], x = 0,1 for Листинг программы Результаты выполнения программы
СКАЧАТЬ
|
|
| |
engineerklub | Дата: Вторник, 10.10.2023, 11:09 | Сообщение # 4 |
Генералиссимус
Группа: Администраторы
Сообщений: 28626
Статус: Online
| Лабораторная работа №3
Тема: Разработка вычислительных программ для обработки случайных и детерминированных числовых последовательностей. Использование подпрограмм.
Цель: закрепление практических навыков в работе с операторами цикла языка C++, формирование навыков работы с генератором случайных чисел, а также умений по обработке числовых последовательностей без применения массивов.
Задание
1. Из приложения Г выбрать свое индивидуальное задание и написать программу на языке С++, которая обрабатывает числовые последовательности и выводит результаты обработки на экран. Если в задании используется число M, то его ввод осуществлять с клавиатуры. Обработку выполнить без использования массивов!!! • Сгенерировать последовательность из N целых случайных чисел, которые находятся в заданном интервале. Для данной последовательности выполнить задание №1. Число N и границы интервала задать целочисленными константами. • Ввести с клавиатуры последовательность ненулевых чисел, 0 – конец последовательности. Для данной последовательности выполнить задание №2.
Вариант Число N Интервал Задание 1 Задание 2 3. 27 -50…50 Определить есть ли в последовательности серии положительных чисел, превышающие 3 элемента Определить общее количество разрядов чисел последовательности
2. Из приложения Д выбрать индивидуальное задание и написать программу, которая вычисляет сумму ряда с точностью ε для всех значений аргумента, меняющегося в заданном интервале с заданным шагом. Также определить количество шагов n для достижения заданной точности ε. Запрограммировать вычисление точного значения функции Y для каждого x (z). Подсчитать ошибку вычислений по формуле: . Результаты выполнения программы представить в следующем виде: Значение аргумента x (z) Сумма ряда S Точное значение Y Относительная ошибка в % Количество шагов n
Форматирование таблицы осуществлять при помощи языковых средств вывода данных, рассмотренных в разделе 5 учебного пособия.
Задача вычисления суммы членов ряда рассмотрена в разделе 10 учебного пособия.
№ вар. Сумма ряда S Значения аргумента Точность ε Функция Y (точное значение) Интервал Шаг 3. Xн=0.1 Xк=1 0.1 10-4 sin(x)
3. Решить задачу 1 с использованием подпрограммы так, чтобы: • ввод элементов последовательности с клавиатуры и вывод результатов их обработки осуществляются в функции main(); • обработка элементов последовательности осуществляются при помощи функции пользователя, необходимые элементы передаются в пользовательскую функцию в качестве параметров. Результаты выполнения модифицированной программы должны совпадать с результатами выполнения исходной программы.
Листинг программы
Результаты выполнения программы
Листинг программы Результаты выполнения программы
Листинг программы
Результаты выполнения программы
СКАЧАТЬ
|
|
| |