Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Microsoft_Visual_C++..doc
Скачиваний:
18
Добавлен:
29.10.2018
Размер:
691.2 Кб
Скачать
    1. В целочисленной прямоугольной таблице замените все от­рицательные элементы на их модули.

    2. Поменяйте местами первую и последнюю строки прямоугольной таблицы.

    3. Квадратичную матрицу состоящую из натуральных чисел повернуть на 90 градусов по часовой стрелке и вывести результат на экран.

    4. Написать программу, которая проверяет, является ли введенная матрица магическим квадратом (сумма элементов которой в каждой строке, в каждом столбе и по каждой диагонали одинакова).

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

    6. В квадратной матрице a[n,m] определить количество строк упорядоченных по возрастанию; упорядоченных по убыванию; неупорядоченных

    7. Задан двумерный массив А размерностью 3×3. Написать программу вычисления суммы и произведения элементов строк и столбцов массива.

    8. Задан двумерный массив А размерностью 3×3. Написать программу вычисления суммы и произведения элементов главной диагонали матрицы.

    9. Задан двумерный массив А размерностью 3×3. Написать программу поиска наибольшего и наименьшего элементов главной диагонали.

    10. Задан двумерный массив А размерностью 3×3. Написать программу поиска наибольшего и наименьшего элемента в каждой строке и столбце массива.

    11. Задан двумерный массив А размерностью 3×3. Написать программу подсчета числа одинаковых и числа различных элементов массива.

      Лабораторная работа № 5

       Функции

  1.  

  2. Цель работы: приобрести навыки в решении задач с использованием функций.

  3.  

  4. Содержание работы

  5.  

  6. 1 Модульное программирование

  7. 2 Объявление функции

  8. Пример 1 Объявление функции

  9. 2 Формальные и фактические параметры функции

  10. Пример 2 Создание функции

  11. Пример 3 Вызов функции

  12. 3 Локальные и глобальные переменные

  13. Пример 4 Вычисления с использованием функции

  14. Задачи

  15. 1 Модульное программирование

  16. Модульность – фундаментальный аспект всех успешно работающих крупных систем.

  17. Бьерн Страуструп 

  18. При разработке программы иногда появляются повторяемые группы действий или возникает необходимость разбить программу на функциональные модули, сделать ее структуру иерархической. Для этого во всех языках программирования существуют средства организации подпрограмм (модулей).

  19. Подпрограмма (модуль) — это специальным образом оформленный алго­ритм, который может многократно использоваться при реше­нии более общей задачи.

  20. Программирование, основанное на разбиение программы на независимые модули, называется модульным.

  21. 2 Объявление функции

  22. Разновидностью подпрограмм являются функции.

  23. До настоящего момента нами были использованы системные функции. Например, выполнение программы всегда начинается с команд, содержащихся в функции main(), а затем последняя вызывает другие функции.

  24. Функция – самостоятельная единица программы, представляющая собой группу операторов, выполняющих законченное действие.

  25. К функции можно обратиться по имени, передать ей значение и получить из нее результат.

  26. Формат объявления функции (прототип функции):

  27. тип имя_функции (список_параметров)

  28. тело функции;

  29. Пример 1 Объявление функции

  30. Прототип функции, возвращающей факториал числа n (факториал числа n – это произведение n!=1*2*…*n, см. лабораторную работу 3, задание 5):

  31. int fact(int n);

  32. Задание 1

  33. В примере 1 определите имя функции, тип функции и параметра.

  34. Это важно

  35. Функцию следует определять так, чтобы ею можно было воспользоваться как черным ящиком. Имя функции должно быть информативным. Программист не должен нуждаться в доступе к ее телу, для того чтобы узнать, что она делает. Вся необходимая информация должна быть приведена в объявлении функции. Данное правило называется принципом процедурной абстракции.

  36. 2 Формальные и фактические параметры функции

  37. Для удобства передачи данных в функцию и получения результата используются фор­мальные и фактические аргументы.

  38. Формальные параметры – условные обозначения в описании функции.

  39. В примере 1 переменная n является формальным параметром.

  40. Фактические параметры – аргументы, с которыми требуется выполнить функцию. Фактические параметры перечисляются при вызове функции.

  41. Пример 2 Создание функции

  42. int fact(int n)

  43. {

  44. int i,p;

  45. p=1;

  46. for (i=1;i<=n;i++)

  47. p=p*i;

  48. return p;

  49. }

  50. Возвращение значения функции (факториала числа n) выполняется с помощью оператора return.

  51. Задание 2

  52. Проанализируйте код функции примера 2.

  53. 3 Локальные и глобальные переменные

  54. В примере 2 вспомогательные переменные i,p будут являться локальными переменными.

  55. Локальные переменные – переменные, которые описываются только внутри подпрограммы (функции) и являющиеся промежуточными при ее выполнении.

  56. Глобальные переменные – переменные, описанные в главной программе.

  57. Пример 3 Вызов функции

  58. На основе функции fact, (см. пример 2) вычислим число сочетаний:

  59. #include "stdafx.h"

  60. #include<iostream>

  61. #include<conio.h>

  62. using namespace std;

  63. // Объявление функции

  64. int fact(int n)

  65. {

  66. int i,p;

  67. p=1;

  68. for (i=1;i<=n;i++)

  69. p=p*i;

  70. return p;

  71. }

  72. //Главная программа

  73. int main(array<System::String ^> ^args)

  74. {

  75. int N,M;

  76. cout<<"Введите значение N ";

  77. cin >> N;

  78. cout<<"Введите значение M, M>N ";

  79. cin >> M;

  80. cout<<"Число сочетаний "<< N << " из " << M << " равно " << fact(N)/fact(N-M)/fact(M);

  81. getch();

  82. return 0;

  83. }

  84. В примере 3 в главной программе функция fact(N) вызывается три раза:

  85. fact(N)/fact(N-M)/fact(M)

  86. соответственно с аргументами N, N-M и M. Переменные N и M являются глобальными.

  87. Тестирование:

  88. Задание 3

  89. Выполните программу примера 3. Создайте функцию ch_s(), возвращающую число сочетаний . Сколько аргументов будет иметь данная функция?

  90. Лабораторная работа № 6

     Элементы объектно-ориентированного программирования

  91.  

  92. Цель работы: приобрести навыки создания собственных классов и познакомиться с основными идеями объектно-ориентированного программирования.

  93.  

  94. Содержание работы

  95.  

  96. 1 Создание класса

  97. Пример 1 Объявление класса

  98. Пример 2 Доступ к членам класса

  99. 2 Полиморфизм

  100. Пример 3 Перегрузка функций

  101. Задачи

  102. 1 Создание класса

  103. Нами были рассмотрены основные принципы структурного программирования на языке С. Основным отличием языка С от С++ является наличие в нем средств объектно-ориентированного программирования.

  104. Объектно-ориентированное программирование основано на классах. Введение понятие класса является естественным развитием идей модульности, рассмотренных в лабораторной работе №5.

  105. Класс – это структурированный тип, включающий в себя в качестве элементов типизированные данные (параметры) и функции, применяемые по отношению к этим данным.

  106. В простейшем случае объявление класса имеет формат:

  107. class имя

  108. {

  109. Закрытые данные и функции

  110. public:

  111. Открытые данные и функции

  112. };

  113. Public – это режим доступа. Элементы с режимом Public, доступны в других частях программы.

  114. В объявлении класса заложен принцип инкапсуляции – объединения данных и функций.

  115. Пример 1 Объявление класса

  116. class circle

  117. {

  118. public:

  119. // Объявление функций – членов класса

  120. double l(float);

  121. double s(float);

  122. };

  123. Задание 1

  124. Определите имя класса примера 1. Какие функции объявлены?

  125. Пример 2 Доступ к членам класса

  126. #include "stdafx.h"

  127. #include<iostream>

  128. #include<conio.h>

  129. #include<math.h>

  130. #define pi 3.14

  131. using namespace std;

  132. // Объявление класса circle (окружность)

  133. class circle

  134. {

  135. public:

  136. double l(float);

  137. double s(float);

  138. };

  139. // Описание функций – членов класса

  140. // Описание функции l от одной переменной(длины окружности от радиуса)

  141. double circle::l(float r)

  142. {

  143. return 2*pi*r;

  144. }

  145. // Описание функции s от одной переменной (площади окружности от радиуса)

  146. double circle::s(float r)

  147. {

  148. return pi*r*r;

  149. }

  150. // Основная программа

  151. int main(array<System::String ^> ^args)

  152. {

  153. // Объявление объекта С – экземпляра класса circle

  154. circle C;

  155. float R;

  156. cout << "Введите значение радиуса окружности R=";

  157. cin>>R;

  158. cout << "Длина окружности равна L=" << C.l(R);

  159. getch();

  160. return 0;

  161. }

  162. Функции, заявленные в классе (l и s) должны быть описаны. Описание функций производится отдельно, после объявления класса. При этом необходимо указать, к какому классу принадлежит данная функция. Для этого к имени функции через двойное двоеточие :: добавляется имя класса, например circle::l и circle::s.

  163. Двойное двоеточие:: – это оператор разрешения области видимости, который квалифицирует имя члена (функции) вместе с именем его класса. Оператор заявляет о том, что функция l принадлежит классу circle. Т.о., различные классы могут использовать одинаковые имена функций благодаря оператору разрешения области видимости.

  164. Чтобы вызвать функцию из части программы, которая находится вне класса, необходимо использовать имя объекта и оператор «точка». Например, в основной программе примера 2 C.l(R)вызывает функцию поиска длины окружности l для окружности C с фактическим значением радиуса R. Вызов C.l(R)возможен, т.к. функция l()в классе circle объявлена как открытая (public).

  165. Задание 2

  166. Выполните тестирование программы примера 2. Добавьте вызов функции s()для объекта С.

  167. 2 Полиморфизм

  168. Полиморфизм (с греч. многообразие форм, poly – много, morphos – форма) можно определить как свойство, позволяющее использовать одно имя для обозначения действий, общих для родственных классов. При этом конкретизация выполняемых действий осуществляется в зависимоти от типа обрабатываемых данных.

  169. В С++ полиморфизм реализован через механизм перегрузки (функций и операций), виртуальные функции и шаблоны.

  170. Рассмотрим механизм перегрузки функций – внутри класса допускается существование нескольких функций с одинаковым именем, но различающимися типами результатов и наборами формальных параметров.

  171. Пример 3 Перегрузка функций

  172. Определим перегруженную функцию l()класса circle, которая возвращает длину окружности и длину дуги . Во втором случае необходимо задать два аргумента: радиус r и угол сектора a в градусах.

  173. #include "stdafx.h"

  174. #include<iostream>

  175. #include<conio.h>

  176. #include<math.h>

  177. #define pi 3.14

  178. using namespace std;

  179. class circle

  180. {

  181. public:

  182. double l(float);

  183. double l(float, float); // Объявление функции l от двух переменных

  184. double s(float);

  185. };

  186. // Описание функций – членов класса

  187. // Описание функции l от одной переменной(длины окружности от радиуса)

  188. double circle::l(float r)

  189. {

  190. return 2*pi*r;

  191. }

  192. // Описание второй функции l от двух переменных (длины дуги от радиуса окружности и угла сектора)

  193. double circle::l(float r, float a)

  194. {

  195. return pi*r*a/180;

  196. }

  197. // Описание функции s от одной переменной (площади окружности от радиуса)

  198. double circle::s(float r)

  199. {

  200. return pi*r*r;

  201. }

  202. // Основная программа

  203. int main(array<System::String ^> ^args)

  204. {

  205. circle C;

  206. float R,A;

  207. cout << "Введите значение радиуса окружности R=";

  208. cin>>R;

  209. cout << "Введите значение угла в градусах А=";

  210. cin>>A;

  211. cout << "Длина окружности равна L=" << C.l(R)<< "\n";

  212. cout << "Длина дуги равна L=" << C.l(R, A);

  213. getch();

  214. return 0;

  215. }

  216. Тестирование:

  217. Задание 3

  218. Выполните перегрузку функции l(), добавив соответствующие строки к программе примера 2. Выполните перегрузку функции circle::s, вычислив площадь сектора:

Лабораторная работа № 7

 Создание оконных приложений

Цель работы: изучить определение, назначение и виды форм; научиться создавать оконные приложения с помощью конструктора форм Windows Forms.

Содержание работы

1 Понятие формы. Конструктор форм Windows Forms

2 Элементы управления

3 Создание приложений с помощью Windows Forms Application

Пример 1 Создание простейшего оконного приложения

Пример 2 Создание идентификационной формы

4 API-функции

Пример 3 Изменение параметров MessageBox.Show

5 Анализ кода

6 Расчетные формы

Пример 4 Создание расчетной формы

Пример 5 Создание простейшего меню

7 Создание оконных приложений на базе MFC

Соседние файлы в предмете [НЕСОРТИРОВАННОЕ]