Типы вычислительных процессов

Содержание

Слайд 2

Типы вычислительных процессов

Линейные

Ветвящиеся

Циклические

Управляющие базовые структуры …

линейной композиции

выбора решения

повторения

Типы вычислительных процессов Линейные Ветвящиеся Циклические Управляющие базовые структуры … линейной композиции выбора решения повторения

Слайд 3

Типы вычислительных процессов

Линейные процессы

- это такой вычислительный процесс, в котором самостоятельные (отдельные)

Типы вычислительных процессов Линейные процессы - это такой вычислительный процесс, в котором
этапы вычислений выполняются в линейной последовательности их записи, т.е. в естественно порядке

Блоки размещаются сверху вниз в порядке их выполнения

Слайд 4

Типы вычислительных процессов

Разветвляющиеся процессы

Разветвляющимся называется такой алгоритм, в котором выбирается один из

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

Двустороннее ветвление

Одностороннее ветвление

Слайд 5

Типы вычислительных процессов

Разветвляющиеся процессы. Особенности обработки разветвляющихся процессов

1. Чтобы из двусторонней

Типы вычислительных процессов Разветвляющиеся процессы. Особенности обработки разветвляющихся процессов 1. Чтобы из
развилки сделать одностороннюю, надо предписание одной из веток (любой) выполнить до условного оператора – это необходимо предпринимать при реализации программ на языках низкого уровня.

2. Для того чтобы в условном операторе поменять ветки местами, условие надо поменять на противоположное.

Операции, которые используются в предикатах: операции отношения и логические операции

Операции отношения:
=, !=, < =, > = , <, >

Отрицание операций отношения:
=, < >, < =, > = , <, >
!=, = , >, < , >=, <=

Слайд 6

Типы вычислительных процессов

Оператор условия If

Может принимать одну из следующих форм

Полный оператор

if «условие»

Типы вычислительных процессов Оператор условия If Может принимать одну из следующих форм
then «оператор 1»
else «оператор 2»

Неполный оператор

if «условие» then «оператор 1»

Слайд 7

Типы вычислительных процессов

Оператор условия If

«оператор 1» и «оператор 2» тоже могут быть

Типы вычислительных процессов Оператор условия If «оператор 1» и «оператор 2» тоже
условными операторами: (на количество вложений нет ограничений)
В неполный оператор можно вложить неполный (а) и полный (б);
В полный оператор также можно вложить неполный (в) и полный операторы.

ВНИМАНИЕ!
else ВСЕГДА ОТНОСИТСЯ К ПОСЛЕДНЕМУ if
Не забывайте про фигурные скобки

Слайд 8

Типы вычислительных процессов

Оператор выбора switch

позволяет выбрать одно из нескольких возможных выполнений программы

Параметром,

Типы вычислительных процессов Оператор выбора switch позволяет выбрать одно из нескольких возможных
по которому осуществляется выбор, служит так называемый ключ выбора (или селектор) - выражение любого простого типа

switch (выражение){
case значение 1: оператор (группа операторов)
break;
case значение 2: оператор (группа операторов)
break;
. . .
default: оператор (группа операторов) break;
}

Слайд 9

Типы вычислительных процессов

Циклические процессы

(часть операторов многократно выполняется при различных значениях переменных)

В языках

Типы вычислительных процессов Циклические процессы (часть операторов многократно выполняется при различных значениях
программирования имеется три разновидности операторов цикла:
1. Оператор с предварительным условием (предусловием);
2. Оператор цикла с последующим условием (постусловием);
3. Оператор цикла с параметром.

Слайд 10

Типы вычислительных процессов

Циклические процессы. Классификация типов циклических процессов

Могут быть вложены один в

Типы вычислительных процессов Циклические процессы. Классификация типов циклических процессов Могут быть вложены
другой.
Необходимо составлять программу так, чтобы внутренний цикл полностью укладывался в циклическую часть внешнего цикла.
На количество вложений цикла в цикл в итерационных циклах ограничений нет

Слайд 11

Типы вычислительных процессов

Циклические процессы

По способу реализации циклы делятся на:

Циклы с предусловием (тип

Типы вычислительных процессов Циклические процессы По способу реализации циклы делятся на: Циклы
«ПОКА»)

Циклы с постусловием (тип «ДО»)

Слайд 12

Типы вычислительных процессов

Циклические процессы

Циклы с предусловием (тип «ПОКА»). Особенности

- Ни разу не

Типы вычислительных процессов Циклические процессы Циклы с предусловием (тип «ПОКА»). Особенности -
выполняется, если условие ложно;

- Если ОПЕРАТОР составной, то он заключается в фигурные скобки. Зачастую оператор должен быть составным, поскольку он включает оператор, который должен повторяться и оператор, который изменяет значение в логическом выражении, иначе будет зацикливание;

- ОПЕРАТОР может быть циклом (причём на количество вложений цикла в цикл ограничений нет).

Слайд 13

Типы вычислительных процессов

Циклические процессы

Циклы с постусловием (тип «ДО»). Особенности

Тело цикла исполняется хотя

Типы вычислительных процессов Циклические процессы Циклы с постусловием (тип «ДО»). Особенности Тело
бы один раз;
ОПЕРАТОР может быть циклом (причём на количество вложений цикла в цикл ограничений нет)

Слайд 14

Типы вычислительных процессов

Циклические процессы

По виду выполнения циклы делятся на:

Арифметический (с параметром, с

Типы вычислительных процессов Циклические процессы По виду выполнения циклы делятся на: Арифметический
известным числом вхождений)

Итерационный (или с неизвестным числом вхождений).
С помощью итерационных циклов решаются задачи, использующие метод последовательных приближений.

Слайд 15

Типы вычислительных процессов

Циклические процессы. Арифметический (цикл с параметром). Особенности

Для досрочного выхода из

Типы вычислительных процессов Циклические процессы. Арифметический (цикл с параметром). Особенности Для досрочного
цикла используются процедуры:
BREAK: передаёт управление на оператор, следующий за циклом;
CONTINUE: передаёт управление на начало тела цикла для следующей итерации

Слайд 16

Типы вычислительных процессов

Логический тип данных

Переменные логического типа описываются как bool
Они могут принимать

Типы вычислительных процессов Логический тип данных Переменные логического типа описываются как bool
только два значения - False (ложь, 0) и
True (истина, 1)
Операции not, and, or и xor

Слайд 17

Типы вычислительных процессов

Логический тип данных

Схема логического умножения A and В

Результат операции and

Типы вычислительных процессов Логический тип данных Схема логического умножения A and В
(и) есть истина, только если оба ее операнда истинны, и ложь во всех других случаях

Слайд 18

Типы вычислительных процессов

Логический тип данных

Схема операции or

Результат операции or (или) есть истина,

Типы вычислительных процессов Логический тип данных Схема операции or Результат операции or
если какой-либо из ее операндов истинен, и ложен только тогда, когда оба операнда ложны

Слайд 19

Типы вычислительных процессов

Логический тип данных

Логические операции имеют более высокий приоритет, поэтому отношения,

Типы вычислительных процессов Логический тип данных Логические операции имеют более высокий приоритет,
стоящие слева и справа от знака логической операции, должны быть заключены в скобки

Принят следующий приоритет операций:
• not
• and, *, /, mod
• or, xor, +, -
• Операции отношения

and - логические умножение

or - логическое сложение

xor - логическое сложение по mod 2

Слайд 20

Типы вычислительных процессов

Логический тип данных

A or B and not (A or B)

1

2

3

4

NOT

Типы вычислительных процессов Логический тип данных A or B and not (A
(( X>2) AND (X<4))

(X<=2) OR (X>=4)

При отрицании сложных предикатов операции отношения меняются на противоположные, а логические OR на AND

Если один условный оператор стоит в ветке «да» второго оператора, то мы можем поместить все в один предикат, в котором условия объединяться логической операций AND

Если один условный оператор стоит в ветке «нет» второго оператора, то они могут быть объединены с помощью операции OR

Слайд 21

Типы вычислительных процессов

Логический тип данных

Рассмотрим задачу

Для функции единичного скачка вывести y для

Типы вычислительных процессов Логический тип данных Рассмотрим задачу Для функции единичного скачка
x, лежащего в следующей области: от 2 до 4, не включая концы отрезков

Слайд 22

Типы вычислительных процессов

Логический тип данных

После выполнения выше сказанного, предикат будет выглядеть следующим

Типы вычислительных процессов Логический тип данных После выполнения выше сказанного, предикат будет
образом:
(x>2) and (x<4)
или
(x <= 2) or (x >= 4)

Слайд 23

Типы вычислительных процессов

Рекуррентные последовательности, рекуррентные алгоритмы

Рекуррентная последовательность

Пусть известно k чисел a1, ...,

Типы вычислительных процессов Рекуррентные последовательности, рекуррентные алгоритмы Рекуррентная последовательность Пусть известно k
аk

Эти числа являются первыми числами числовой последовательности

Следующие элементы данной последовательности вычисляются так:

F— функция от k аргументов

 

 

Величина k называется глубиной рекурсии

Слайд 24

Типы вычислительных процессов

Рекуррентные последовательности, рекуррентные алгоритмы

Рекуррентная последовательность

— это бесконечный ряд чисел, каждое

Типы вычислительных процессов Рекуррентные последовательности, рекуррентные алгоритмы Рекуррентная последовательность — это бесконечный
из которых, за исключением k начальных, выражается через предыдущие

Примерами рекуррентных последовательностей являются арифметическая(1) и геометрическая (2) прогрессии

 

 

 

 

Слайд 25

Типы вычислительных процессов

Рекуррентные последовательности, рекуррентные алгоритмы

Рекуррентная последовательность

В целом рекуррентная последовательность описывается совокупностью

Типы вычислительных процессов Рекуррентные последовательности, рекуррентные алгоритмы Рекуррентная последовательность В целом рекуррентная
начальных значений и рекуррентной формулы

Для арифметической и геометрической прогрессии формулы можно объединить в ветвящуюся формулу

Для арифметической прогрессии

 

Для геометрической прогрессии

 

Глубина рекурсии в обоих случаях равна единице (такую зависимость еще называют одношаговой рекурсией)

Слайд 26

Типы вычислительных процессов

Рекуррентные последовательности, рекуррентные алгоритмы

Рекуррентная последовательность

Числа Фибоначчи

Начиная с третьего элемента каждое

Типы вычислительных процессов Рекуррентные последовательности, рекуррентные алгоритмы Рекуррентная последовательность Числа Фибоначчи Начиная
число равно сумме значений двух предыдущих

Это рекуррентная последовательность с глубиной равной 2 (двухшаговая рекурсия)

 

Слайд 27

Типы вычислительных процессов

Рекуррентные последовательности, рекуррентные алгоритмы

Рекуррентная последовательность

Факториал целого числа n!

Это значение n-го

Типы вычислительных процессов Рекуррентные последовательности, рекуррентные алгоритмы Рекуррентная последовательность Факториал целого числа
элемента следующего ряда чисел

 

Тогда рекуррентное описание такой последовательности

 

Слайд 28

Типы вычислительных процессов

Рекуррентные последовательности, рекуррентные алгоритмы

С рекуррентными последовательностями связаны задачи такого рода:
вычислить

Типы вычислительных процессов Рекуррентные последовательности, рекуррентные алгоритмы С рекуррентными последовательностями связаны задачи
заданный (n-й) элемент последовательности;
2) математически обработать определенную часть последовательности (например, вычислить сумму или произведение первых n членов);
3) подсчитать количество элементов на заданном отрезке последовательности, удовлетворяющих определенным свойствам;
4) определить номер первого элемента, удовлетворяющего определенному условию;
5) вычислить и сохранить в памяти заданное количество элементов последовательности

Слайд 29

Типы вычислительных процессов

Рекуррентные последовательности, рекуррентные алгоритмы

Пример

Для заданного натурального N и вещественного х

Типы вычислительных процессов Рекуррентные последовательности, рекуррентные алгоритмы Пример Для заданного натурального N
(х > 0) вычислить значение выражения

Слайд 30

Типы вычислительных процессов

Методы проверки правильности алгоритмов

Корректность программы – это соответствие ее функциональности

Типы вычислительных процессов Методы проверки правильности алгоритмов Корректность программы – это соответствие
требованиям

Это и проверка исходного кода, и поиск типовых ошибок в коде, и тестирование программы (имеется в виду запуск программы на каких-либо примерах), и имитационное моделирование, и формальная верификация (логическая модель программы и анализ ее математическими средствами)

Слайд 31

Типы вычислительных процессов

Методы проверки правильности алгоритмов

Аналитическое доказательство правильности работы программы называют верификацией

Доказательство

Типы вычислительных процессов Методы проверки правильности алгоритмов Аналитическое доказательство правильности работы программы
правильности работы программ методом логического преобразования предикатов. Основано на логике высказываний.
b) Верификация с помощью таблицы трассировки

Слайд 32

Типы вычислительных процессов

Методы проверки правильности алгоритмов

Пример 1. Надо поменять содержимое ячеек x

Типы вычислительных процессов Методы проверки правильности алгоритмов Пример 1. Надо поменять содержимое
и y местами

Слайд 33

Типы вычислительных процессов

Методы проверки правильности алгоритмов

Пример 2. Докажем правильность менее простого алгоритма

[0]

Типы вычислительных процессов Методы проверки правильности алгоритмов Пример 2. Докажем правильность менее
x = x + y
[1] y = x – y
[2] x = x – y

Покажем, что x3 = y0, y3 = x0

x3 = x2 – y2 = x1 – (x1 – y1) = y1 = y0, т.е. x3 = y0
y3 = x1 – y1 = x0 + y0 – y0 = x0, т.е. y3 = x0

Слайд 34

Типы вычислительных процессов

Методы проверки правильности алгоритмов

Тестирование вручную

Производится расчет значений выходных данных по

Типы вычислительных процессов Методы проверки правильности алгоритмов Тестирование вручную Производится расчет значений
фиксированному набору входных данных

В случае выявления ошибки производится ее поиск с помощью промежуточных данных (метод локализации ошибки)

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

Слайд 35

Типы вычислительных процессов

Методы проверки правильности алгоритмов

Пример. Вычислим факториал числа N

Ввод N
F =

Типы вычислительных процессов Методы проверки правильности алгоритмов Пример. Вычислим факториал числа N
1
Пока N > 1
F = F * N
N = N – 1
Вывод F

Пример трассировки программы для значения N равного 7

7! = 7*6*5*4*3*2*1 = 5040

Слайд 36

Типы вычислительных процессов

Методы проверки правильности алгоритмов

Типы вычислительных процессов Методы проверки правильности алгоритмов
Имя файла: Типы-вычислительных-процессов.pptx
Количество просмотров: 39
Количество скачиваний: 0