Программирование на Python. Алгоритмы и структуры данных. Часть 1. 10 занятие

Содержание

Слайд 2

2

СОДЕРЖАНИЕ

1. ВВЕДЕНИЕ. ОРГАНИЗАЦИОННАЯ ИНФОРМАЦИЯ
Тема занятия 
Цели и задачи занятия 
Результаты занятия 
Материалы для преподавателя
Материалы для

2 СОДЕРЖАНИЕ 1. ВВЕДЕНИЕ. ОРГАНИЗАЦИОННАЯ ИНФОРМАЦИЯ Тема занятия Цели и задачи занятия
ученика 
Тайминг проведения занятия 
2. ТЕОРЕТИЧЕСКАЯ ЧАСТЬ
Алгоритмы
Классы алгоритмов
Семейство алгоритмов сортировки
3. ПРАКТИЧЕСКАЯ ЧАСТЬ 
Обзор базовых алгоритмов
Оценка временной сложности
Подходы к оптимизации кода
Эффективность кода

АЛГОРИТМЫ И СТРУКТУРЫ ДАННЫХ.
ЧАСТЬ 1.

 inginirium.ru

Слайд 3

ВВЕДЕНИЕ.
ОРГАНИЗАЦИОННАЯ ИНФОРМАЦИЯ 

3

АЛГОРИТМЫ И СТРУКТУРЫ ДАННЫХ.
ЧАСТЬ 1.

Тема: Алгоритмы и структуры данных. Часть

ВВЕДЕНИЕ. ОРГАНИЗАЦИОННАЯ ИНФОРМАЦИЯ 3 АЛГОРИТМЫ И СТРУКТУРЫ ДАННЫХ. ЧАСТЬ 1. Тема: Алгоритмы
1.
Цели и задачи:
Рассказать об определении алгоритма.
Рассказать о современных подходах к оптимизации кода.
Рассказать про общую алгоритмическую сложность.
Описать основные классы алгоритмов.
Рассмотреть базовые алгоритмы сортировки.
Рассказать про оценку временной сложности.
По результатам занятия слушатель будет знать: 
Что такое алгоритмы и для чего их использовать.
Какие существуют классы алгоритмов.
Какие есть виды алгоритмов сортировки.

 inginirium.ru

Слайд 4

4

Тема: Алгоритмы и структуры данных. Часть 1. 

По результатам занятия слушатель будет уметь: 

4 Тема: Алгоритмы и структуры данных. Часть 1. По результатам занятия слушатель
Использовать базовые алгоритмы в программном коде.
Работать с оценкой сложности и видоизменять структуру классических алгоритмов.
Оптимизировать и увеличивать эффективность программного кода.
Тайминг занятия

АЛГОРИТМЫ И СТРУКТУРЫ ДАННЫХ.
ЧАСТЬ 1.

Таб.1

 inginirium.ru

Слайд 5

5

Тема: Алгоритмы и структуры данных. Часть 1. 

Алгоритмы
1.1 Что такое алгоритмы? Алгоритмы - конечная

5 Тема: Алгоритмы и структуры данных. Часть 1. Алгоритмы 1.1 Что такое
совокупность точно заданных правил решения определенных задач, приводящие к определенному и однозначному результату. 1.2 Для чего они нужны? Алгоритмы необходимы для увеличения эффективности программного кода : уменьшения времени выполнения, уменьшения затрат памяти. 1.3 Почему их необходимо использовать. Применение алгоритмов в программном коде позволяет коду решать более общую задачу без потери эффективности. Стоить заметить, что для решения одной и той же задачи могут быть пригодны несколько видов алгоритмов. Главной задачей программиста является классификация задачи и выбор наиболее подходящего для данной задачи алгоритма.

АЛГОРИТМЫ И СТРУКТУРЫ ДАННЫХ.
ЧАСТЬ 1.

 inginirium.ru

Слайд 6

6

Тема: Алгоритмы и структуры данных. Часть 1. 

2. Базовые алгоритмы
2.1 Алгоритмы сортировки -

6 Тема: Алгоритмы и структуры данных. Часть 1. 2. Базовые алгоритмы 2.1
это алгоритм для упорядочивания элементов в хранилище. Алгоритмы сортировки - отдельный класс алгоритмов, решающий исключительно одну задачу - задачу упорядочивания элементов в хранилище. 2.2 Почему нам нужно сортировать объекты Упорядоченные наборы элементов (как следствие своей упорядоченности) позволяют находить наименьший или наибольший элемент в списке, выделять упорядоченные подпоследовательности. Основная идея - изменить порядок элементов в хранилище по определенному правилу сравнений элементов друг с другом.

АЛГОРИТМЫ И СТРУКТУРЫ ДАННЫХ.
ЧАСТЬ 1.

 inginirium.ru

Слайд 7

7

Тема: Алгоритмы и структуры данных. Часть 1. 

2.3 Реализация алгоритмов сортировки
2.3.1 Пузырек Сортировка пузырьком

7 Тема: Алгоритмы и структуры данных. Часть 1. 2.3 Реализация алгоритмов сортировки
- простейший из семейства алгоритмов сортировки. Эффективен только для небольших массивов. Сортировка пузырьком - это метод сортировки массивов и списков путем последовательного сравнения и обмена соседних элементов, если предшествующий оказывается больше последующего.
В сортировке методом пузырька количество итераций внешнего цикла определяется длинной списка минус единица, так как когда второй элемент становится на свое место, то первый уже однозначно минимальный и находится на своем месте.

АЛГОРИТМЫ И СТРУКТУРЫ ДАННЫХ.
ЧАСТЬ 1.

 inginirium.ru

Слайд 8

8

Тема: Алгоритмы и структуры данных. Часть 1. 

Пусть имеется список [6, 12, 4, 3,

8 Тема: Алгоритмы и структуры данных. Часть 1. Пусть имеется список [6,
8]. 
За первую итерацию внешнего цикла число 12 переместится в конец. Для этого потребуется 4 сравнения во внутреннем цикле:
6 > 12? Нет
12 > 4? Да. Меняем местами
12 > 3? Да. Меняем местами
12 > 8? Да. Меняем местами
Результат: [6, 4, 3, 8, 12]
# Далее попробуйте отсортировать список самостоятельно
Результат: [3, 4, 6, 8, 12]

АЛГОРИТМЫ И СТРУКТУРЫ ДАННЫХ.
ЧАСТЬ 1.

 inginirium.ru

Слайд 9

9

Тема: Алгоритмы и структуры данных. Часть 1. 

2.3.2 Мердж
Сортировка слиянием (merge sort) -

9 Тема: Алгоритмы и структуры данных. Часть 1. 2.3.2 Мердж Сортировка слиянием
алгоритм сортировки, основанный на принципе "разделяй и властвуй". Сначала главная задача разбивается на несколько подзадач меньшего размера. Затем эти подзадачи разбиваются на подподзадачи и так далее. В самом конце, решения элементарных подзадач комбинируются и получается исходное решение задачи.

АЛГОРИТМЫ И СТРУКТУРЫ ДАННЫХ.
ЧАСТЬ 1.

 inginirium.ru

Слайд 10

10

Тема: Алгоритмы и структуры данных. Часть 1. 

2.3.3 Квиксорт
Быстрая сортировка (quick sort) -

10 Тема: Алгоритмы и структуры данных. Часть 1. 2.3.3 Квиксорт Быстрая сортировка
один из самых быстрых и широкоизвестных алгоритмов сортировки, использующийся в промышленном программировании с некоторыми доработками. Основан на принципах bubble sort, но имеет ряд принципиальных отличий. В первую очередь производятся перестановки на наибольшем возможном расстоянии и после каждого прохода (шага сортировки) элементы делятся на пары независимых групп.

АЛГОРИТМЫ И СТРУКТУРЫ ДАННЫХ.
ЧАСТЬ 1.

 inginirium.ru

Слайд 11

11

Тема: Алгоритмы и структуры данных. Часть 1. 

3. Сложность
3.1 Об оценке эффективности алгоритма Эффективность

11 Тема: Алгоритмы и структуры данных. Часть 1. 3. Сложность 3.1 Об
алгоритма - свойство алгоритма, связанное с вычислительными ресурсами при использовании алгоритма. Чаще всего это время выполнения и память. Оценивать эффективность необходимо для того, чтобы доказать, что "алгоритм А справляется с задачей лучше, чем алгоритм Б". 3.2 Затраты по памяти Оценка эффекивности по памяти - как много рабочей памяти (RAM) нужно для алгоритма. Нюансы: количество памяти для кода и количество памяти для данных, с которыми код работает. Оценка по памяти - используется редко, т.к. сильно зависит от машины.

АЛГОРИТМЫ И СТРУКТУРЫ ДАННЫХ.
ЧАСТЬ 1.

 inginirium.ru

Имя файла: Программирование-на-Python.-Алгоритмы-и-структуры-данных.-Часть-1.-10-занятие.pptx
Количество просмотров: 60
Количество скачиваний: 0