Пример записи алгоритма на школьном АЯ
алг Сумма квадратов (арг цел n, рез цел S) дано | n > 0 надо | S = 1*1 + 2*2 + 3*3 +... + n*n нач цел i ввод n; S: =0 нц для i от 1 до n S: =S+i*i кц вывод " S = ", S кон 7.9. Что такое базовые алгоритмические структуры? Алгоритмы можно представлять как некоторые структуры, состоящие из отдельных базовых (т.е. основных) элементов. Естественно, что при таком подходе к алгоритмам изучение основных принципов их конструирования должно начинаться с изучения этих базовых элементов. Для их описания будем использовать язык схем алгоритмов и школьный алгоритмический язык.
Характерной особенностью базовых структур является наличие в них одного входа и одного выхода. 1. Базовая структура " следование". Образуется последовательностью действий, следующих одно за другим:
2. Базовая структура " ветвление". Обеспечивает в зависимости от результата проверки условия (да или нет) выбор одного из альтернативных путей работы алгоритма. Каждый из путей ведет к общему выходу, так что работа алгоритма будет продолжаться независимо от того, какой путь будет выбран. Структура ветвление существует в четырех основных вариантах: · если—то; · если—то—иначе; · выбор; · выбор—иначе.
Примеры структуры ветвление
3. Базовая структура " цикл". Обеспечивает многократное выполнение некоторой совокупности действий, которая называется телом цикла. Основные разновидности циклов представлены в таблице:
Примеры структуры цикл
7.10. Какие циклы называют итерационными?
На каждом шаге вычислений происходит последовательное приближение к искомому результату и проверка условия достижения последнего. Пример. Составить алгоритм вычисления бесконечной суммы
Вычисление сумм — типичная циклическая задача. Особенностью же нашей конкретной задачи является то, что число слагаемых (а, следовательно, и число повторений тела цикла) заранее неизвестно. Поэтому выполнение цикла должно завершиться в момент достижения требуемой точности. При составлении алгоритма нужно учесть, что знаки слагаемых чередуются и степень числа х в числителях слагаемых возрастает. Решая эту задачу " в лоб" путем вычисления на каждом i -ом шаге частичной суммы S: =S + ((-1)**(i-1)) * (x**i) / i,
Сравните эти два подхода по числу операций.
Алгоритм, в состав которого входит итерационный цикл, называется итеpационным алгоpитмом. Итерационные алгоритмы используются при реализации итерационных численных методов. В итерационных алгоритмах необходимо обеспечить обязательное достижение условия выхода из цикла (сходимость итерационного процесса). В противном случае произойдет " зацикливание" алгоритма, т.е. не будет выполняться основное свойство алгоритма — результативность. 7.11. Что такое вложенные циклы? Возможны случаи, когда внутри тела цикла необходимо повторять некоторую последовательность операторов, т. е. организовать внутренний цикл. Такая структура получила название цикла в цикле или вложенных циклов. Глубина вложения циклов (то есть количество вложенных друг в друга циклов) может быть различной. При использовании такой структуры для экономии машинного времени необходимо выносить из внутреннего цикла во внешний все операторы, которые не зависят от параметра внутреннего цикла.
|