Презентация ПЯВУ. Лекция 12. Элементы ООП онлайн

На нашем сайте вы можете скачать и просмотреть онлайн доклад-презентацию на тему ПЯВУ. Лекция 12. Элементы ООП абсолютно бесплатно. Урок-презентация на эту тему содержит всего 35 слайдов. Все материалы созданы в программе PowerPoint и имеют формат ppt или же pptx. Материалы и темы для презентаций взяты из открытых источников и загружены их авторами, за качество и достоверность информации в них администрация сайта не отвечает, все права принадлежат их создателям. Если вы нашли то, что искали, отблагодарите авторов - поделитесь ссылкой в социальных сетях, а наш сайт добавьте в закладки.
Презентации » Устройства и комплектующие » ПЯВУ. Лекция 12. Элементы ООП



Оцените!
Оцените презентацию от 1 до 5 баллов!
  • Тип файла:
    ppt / pptx (powerpoint)
  • Всего слайдов:
    35 слайдов
  • Для класса:
    1,2,3,4,5,6,7,8,9,10,11
  • Размер файла:
    179.75 kB
  • Просмотров:
    60
  • Скачиваний:
    0
  • Автор:
    неизвестен



Слайды и текст к этой презентации:

№1 слайд
ПЯВУ. Лекция . Элементы ООП.
Содержание слайда: ПЯВУ. Лекция 12. Элементы ООП. А.М. Задорожный

№2 слайд
Контрольные вопросы Где можно
Содержание слайда: Контрольные вопросы Где можно и где нельзя использовать каждую конкретную переменную, например double x? (Где она определена, видна?) Что такое гистограмма в смысле программирования? Что такое Конструктор? В чем его особенности в C#? Как создать объект в C#? Как вызвать метод для конкретного объекта в C#? Как вызвать статический метод в C#?

№3 слайд
План лекции Еще об ООП
Содержание слайда: План лекции Еще об ООП Сравнение с функциональным подходом “Эластичность” ООП Класс точки. Алгоритм выяснения находится ли точка внутри полигона. Статические и обычные методы Фильтры Пример класса сортировок. Сортировка выбором, вставкой и шейкер.

№4 слайд
ООП и организация программы
Содержание слайда: ООП и организация программы Функциональный подход: Переменная, операции применимые к типу (int i: +, -, *, /, %, ++, --, +=, -=, …) ООП: Объект: Данные гистограммы Методы работы

№5 слайд
Гистограмма. Функциональный
Содержание слайда: Гистограмма. Функциональный подход Гистограмма в функциональном подходе { Random r = new Random(); int [] hist = new int [10]; for(int i = 0; i < 1000; i++) Hist(10*r.NextDouble(), hist, 0, 10); WriteHist(hist); Console.WriteLine(MeanValue(0,10, hist)); }

№6 слайд
Гистограмма. ООП подход
Содержание слайда: Гистограмма. ООП подход Гистограмма в ООП { Random r = new Random(); Histogram h = new Histogram (0, 10, 10); for(int i = 0; i < 1000; i++) h.Hist(10*r.NextDouble()); h.Write(); Console.WriteLine(h.MeanValue()); }

№7 слайд
ООП. Эластичность I
Содержание слайда: ООП. Эластичность I Эластичность – простота изменения программы при изменении требований. Изменить диапазон чисел с [0, 10], до [-5, 5] и увеличить количество каналов до 25. int [] hist = new int [25]; for(int i = 0; i < 1000; i++) Hist(100*r.NextDouble()-10, hist, -5, 5); WriteHist(hist); Console.WriteLine(MeanValue(-5, 5, hist)); Понадобилось 5 изменений в 3-х строках кода!

№8 слайд
ООП. Эластичность I
Содержание слайда: ООП. Эластичность I Эластичность – простота изменения программы при изменении требований. Изменить диапазон чисел с [0, 10], до [-5, 5] и увеличить количество каналов до 25. Histogram h = new Histogram (-5, 5, 25); for(int i = 0; i < 1000; i++) h.Hist(10*r.NextDouble()); h.Write(); Console.WriteLine(h.MeanValue()); Понадобилось 3 изменения в 1-ой строке кода!

№9 слайд
ООП. Эластичность II
Содержание слайда: ООП. Эластичность II Изменяться могут не только параметры задачи, изменяться могут требования. Связать с каждой гистограммой заголовок, при выводе гистограммы выводить заголовок и диапазон, в котором строилась гистограмма.

№10 слайд
ООП. Эластичность II Добавим
Содержание слайда: ООП. Эластичность II Добавим данные в гистограмму (заголовок) public class Histogram { public double LeftEdge; public double RightEdge; public int [] Data; // Массив public string Title; public Histogram(string title, double leftEdge, double rightEdge, int N) { Title = title; LeftEdge = leftEdge; RightEdge = rightEdge; Data = new int[N]; } public void Hist(double x){ … } public double MeanValue () { … } public double Write() { … } }

№11 слайд
ООП. Эластичность II
Содержание слайда: ООП. Эластичность II Доработаем метод Write public class Histogram { … public double Write() { Console.WriteLine(“Гистограмма ‘{0}’”, Title); Console.WriteLine(“Диапазон [{0}, {1}]”, LeftEdge, RightEdge); Console.Write(h[0]); for(int i = 1; i < h.Length; i++) Console.Write(“, {0}”, h[i]); Console.WriteLine(); } }

№12 слайд
ООП. Эластичность II
Содержание слайда: ООП. Эластичность II Использование гистограммы: Histogram h = new Histogram (“Проверка Random”, -5, 5, 25); for(int i = 0; i < 1000; i++) h.Hist(10*r.NextDouble()); h.Write(); Console.WriteLine(h.MeanValue());

№13 слайд
ООП. Выводы На примере
Содержание слайда: ООП. Выводы На примере гистограммы: ООП позволяет строить понятия более сложные чем заложенные в язык примитивы: числа, строки Вызовы методов стали короче (легче изменять программу, если вызовов много) Потенциально меньше ошибок (нельзя спутать или изменить границы, изменить массив результатов) Потенциально ясно, что чем больше гистограмм, тем приведенные выше факторы будут влиять все больше. Не нужно помнить, какие методы есть у класса (Visual Studio сама подскажет) Легче развивать функции гистограммы. В основном меняются методы и данные класса, а в программе, которая использует этот инструмент изменений мало.

№14 слайд
Вопросы для обсуждения В чем
Содержание слайда: Вопросы для обсуждения В чем преимущества ООП? Как изменится гистограмма, если нужно для каждой гистограммы учитывать и выводить сколько данных оказалось вне диапазона (левее или правее) гистограммы? Как ООП влияет на применение (использование) разработанной функциональности программы, например, построение гистограмм? Как ООП влияет на развитие функциональности программы, например, улучшение метода вывода гистограммы? Как ООП влияет на изучение разработанной функциональности?

№15 слайд
Контрольные вопросы Где нужно
Содержание слайда: Контрольные вопросы Где нужно объявить переменную, которая будет использоваться только в одном методе? Где нужно объявить переменную, которая будет использоваться в нескольких методах класса? Как следует поступить программисту, если ему нужно разработать алгоритм, который будет использовать более сложные конструкции, чем отдельные числа или строки, например, точки на плоскости или в пространстве, комплексные числа, описания студентов, описания состояния компьютерной игры?

№16 слайд
Геометрия
Содержание слайда: Геометрия

№17 слайд
Геометрия
Содержание слайда: Геометрия

№18 слайд
Представление полигона class
Содержание слайда: Представление полигона class Point { public double x; public double y; } Point [] poly; … // Что бы получился замкнутый полигон первая и // последняя точка должны быть соединены

№19 слайд
Геометрия
Содержание слайда: Геометрия

№20 слайд
Алгоритм подсчет пересечений
Содержание слайда: Алгоритм (подсчет пересечений) Для y == Ay x == Ax Для y == By x == Bx х – координата пересечения луча и отрезка! Действия оптимизированы для вычисления количества пересечений!

№21 слайд
Алгоритм подсчет пересечений
Содержание слайда: Алгоритм (подсчет пересечений) bool IsPointInsidePolygon(Point[] poly, Point p) { bool c = false; for (int i = 0, j = poly.Length - 1; i < poly.Length; j = i++) { if ((((poly[i].y <= p.y) && (p.y < poly[j].y)) || ((poly[j].y <= p.y) && (p.y < poly[i].y))) && (p.x < (poly[j].x - poly[i].x) * (p.y - poly[i].y) / (poly[j].y - poly[i].y) + poly[i].x)) c = !c; } return c; }

№22 слайд
Упражнения Доказать, что при
Содержание слайда: Упражнения Доказать, что при выполнении условия, луч пересекает отрезок ломаной! Когда IsPointInsidePolygon не может быть выполнен? Доработайте метод IsPointInsidePolygon так, что бы он безошибочно работал для всех полигонов (имея ввиду ответ на предыдущий вопрос).

№23 слайд
ООП. Статические методы Вызов
Содержание слайда: ООП. Статические методы Вызов обычного метода (метода объекта) Histogram h = new Histogram (“Проверка Random”, -5, 5, 25); … h.Write(); A Вместе с объектом (h) метод Write получил и все данные объекта!

№24 слайд
ООП. Статические методы Вызов
Содержание слайда: ООП. Статические методы Вызов статического метода (метода класса) double [] d = …. // За полнили массив данными double [] fd = Filter. RunningAvrgFilter(d, N); Статический метод не применяется к объекту! V Он не может использовать данные объекта!

№25 слайд
Класс сортировок public
Содержание слайда: Класс сортировок public static class Sorter { public static void BubbleSort(double [] a) { for(int j = 1; j < a.Length; j++) { bool sorted = true; for(int i = 0; i < a.Length - j; i++) if(a[i]>a[i + 1]) { double x = a[i]; a[i] = a[i + 1]; a[i + 1] = x; sorted = false; } if(sorted) break; } } }

№26 слайд
Сортировка выбором Иногда
Содержание слайда: Сортировка выбором Иногда оказывается, что обмен переменных значениями (перестановка элементов в массива) довольно дорогая операция. В таких случаях лучше применять “сортировку выбором”. Пусть имеется массив длиной N. Тогда алгоритм может быть описан так: Номер текущего элемента j = 0; Для j от 0 до N-1 Находим номер наименьшего элемента i, начиная с j; Обмениваем значениями элементы с номерами i и j; Увеличиваем j на 1 и переходим к 2. по окончании цикла массив отсортирован в порядке возрастания.

№27 слайд
Класс сортировок public
Содержание слайда: Класс сортировок public static class Sorter { public static void BubbleSort(double [] a) {…} public static void SelectionSort(double [] a) { for(int j = 0; j < a.Length-1; j++) { int m = j; for(int i = j; i < a.Length; i++) if(a[i]<a[m]) m = i; if(j != m){ double x = a[j]; a[j] = a[m]; a[m] = x; } } } }

№28 слайд
Сортировка вставкой Метод
Содержание слайда: Сортировка вставкой Метод сортировки вставками полезен, когда нужно строить отсортированную последовательность поступающих данных. Идея метода заключается в том, что рассматриваем отсортированную часть массива и новый (неотсортированный) элемент. В отсортированной части массива: находим место для нового элемента, большие элементы сдвигаем вправо и помещаем новый элемент на нужное место. Таким образом, отсортированная часть массива увеличивается.

№29 слайд
Класс сортировок public
Содержание слайда: Класс сортировок public static class Sorter { public static void BubbleSort(double [] a) {…} public static void SelectionSort(double [] a) public static void InsertionSort(double [] a) { for(int j = 1; j < a.Length; j++) { double x = a[j]; int i = j; for(; i > 0 && x < a[i-1]; i--) a[i] = a[i-1]; a[i] = x; } } }

№30 слайд
Сортировка шейкер Мы улучшали
Содержание слайда: Сортировка “шейкер” Мы улучшали сортировку пузырьком, останавливая ее, если по ходу итерации не было ни одной перестановки. Ее можно “оптимизировать” дополнительно, имея ввиду, что если, например, в начале массива не было ни одной перестановки, то их не будет и в последующем. Это и есть идея ShakerSort (CocktailSort). Здесь проход по массиву выполняется сначала слева-направо, потом в обратном порядке. И каждый раз запоминается положение последней перестановки.

№31 слайд
Класс сортировок public
Содержание слайда: Класс сортировок public static class Sorter { public static void BubbleSort(double [] a) {…} public static void SelectionSort(double [] a) {…} public static void InsertionSort(double [] a) {…} public static void ShakerSort(double [] a) {…} { … } }

№32 слайд
Класс сортировок Шейкер
Содержание слайда: Класс сортировок Шейкер public static void ShakerSort(double [] a) { double left = 0, right = a.Length – 1, c; do { c = 0; for (int j = left; j < right; j++) if (a[j] > a[j + 1]) { double x = a[j]; a[j] = a[j + 1]; a[j + 1] = x; c = j; } right = c; for (int j = right; j > left; j--) if (a[j - 1] > a[j]) { double x = a[j]; a[j] = a[j - 1]; a[j - 1] = x; c = j; } left = c; } while (c != 0); }

№33 слайд
Класс сортировок Применение
Содержание слайда: Класс сортировок Применение Double [] d = new Double[15]; Random r = new Random(); for(int i = 0; i < d.Length; i++) d[i] = r.Next(25); Sorter.BubbleSort(a); или Sorter.SelectionSort(a); или Sorter. ShakerSort(a);

№34 слайд
Контрольные вопросы Зачем
Содержание слайда: Контрольные вопросы Зачем применяются статические методы? Почему все методы сортировки объявлены как static? Зачем может применяться сортировка “выбором”? Когда применение алгоритма сортировки вставкой наиболее естественно? В чем идея метода сортировки Shaker? Чем он отличается от улучшенного метода сортировки пузырьком?

№35 слайд
Вопросы для повторения Что
Содержание слайда: Вопросы для повторения Что определяет Тип данных? Что такое массив? Сколько операция сравнения определено для чисел в C#? Сколько операций сравнения определено для строк в C#? Сколько в C# определено булевских операций? Какие операции можно выполнять над булевскими величинами?

Скачать все slide презентации ПЯВУ. Лекция 12. Элементы ООП одним архивом: