Автор работы: Пользователь скрыл имя, 19 Января 2014 в 16:09, реферат
Понятие алгоритма является одним из основных понятий вычислительной математики, однако, оно возникло в связи с поисками общих методов решения однотипных задач задолго до появления вычислительных машин. Еще в III веке до н.э. греческий математик Евклид изложил правило вычисления наибольшего общего делителя двух натуральных чисел. Это правило историки математики считают первым алгоритмом, хотя само слово "алгоритм" появилось гораздо позднее.
Введение 3
1. История 4
2. Понятие алгоритма. Сущность алгоритмизации 8
3. Свойства алгоритма 9
5. Типовые структуры алгоритмов 13
5.1. Линейная структура 13
5.2. Разветвляющаяся структура 13
5.3. Циклическая структура 13
Заключение 15
Литература 16
Министерство Образования
Российской Федерации
Дальневосточный Федеральный Университет
(ДВФУ)
Школа экономики и менеджмента
Реферат:
«История алгоритма»
Дисциплина: Программирование.
Выполнила: ст. гр. Б1104
Иванова Ирина Ивановна.
Проверил: Тихоновская Галина
Ивановна
– преподаватель, доцент.
Владивосток, 2013 г.
Оглавление
Введение 3
1. История 4
2. Понятие
алгоритма. Сущность
3. Свойства алгоритма 9
5. Типовые структуры алгоритмов 13
5.1. Линейная структура 13
5.2. Разветвляющаяся структура 13
5.3. Циклическая структура 13
Заключение 15
Литература 16
Введение
Понятие алгоритма является
одним из основных понятий вычислительной
математики, однако, оно возникло в
связи с поисками общих методов
решения однотипных задач задолго
до появления вычислительных машин.
Еще в III веке до н.э. греческий математик
Евклид изложил правило вычисления наибольшего
общего делителя двух натуральных чисел.
Это правило историки математики считают
первым алгоритмом, хотя само слово "алгоритм"
появилось гораздо позднее.
1. История
Древнегреческий ученый Эратосфен (II в. до н. э.) предложил способ получения простых чисел (т.н. "решето Эратосфена"). В IX в. узбекский математик Мухаммад Ал-Хорезми разработал правила четырех арифметических действий над числами. В Европе эти правила стали называть алгоритмами (от латинской формы написания имени автора - Alchorismi илиAlgorithmi). Переводы арифметического трактата Ал-Хорезми с арабского содержали описание индийской позиционной системы счисления и искусства счета в этой системе (например, алгоритм сложения "столбиком"). Таким образом, сначала понятие "алгоритм" обозначало десятичную позиционную арифметику и процедуры цифровых вычислений.
Долгое время понятие алгоритма было чисто интуитивным, его можно выразить примерно так: алгоритм - это строгая система правил, которая определяет последовательность действий над некоторыми объектами и после конечного числа шагов приводит к достижению поставленной цели. В частности, система правил является алгоритмом, если любые исполнители, не знакомые с существом задачи, строго следуя данной системе правил, будут действовать одинаково и достигнут одного и того же результата.
Суть упомянутого выше алгоритма Евклида состоит в том, чтобы вычитать из большего числа меньшее, подставляя результат на место большего числа, до тех пор, пока числа не станут равны друг другу. Эти равные числа и будут наибольшим общим делителем их разности и любого из чисел. Идея алгоритма понятна, но требует уточнения для использования ее на практике. Более конкретно алгоритм выглядит следующим образом:
А. Сравнить первое и второе числа. Если они равны, перейти к п. Г. Если нет, то перейти к п.Б.
Б. Если первое число меньше второго, то переставить их. Перейти к п.В.
В. Вычесть из первого числа второе
и рассмотреть полученную разность как
новое первое число. Перейти к п.А.
Г. Считать первое
число результатом задачи.
Этот набор правил является алгоритмом, т.к. любой человек, следуя ему, получит наибольший общий делитель для любой пары чисел.
Математики долго пользовались такими словесными описаниями алгоритмов. Многие вычислительные алгоритмы формулировались именно в такой форме (например, алгоритмы поиска корней квадратных и кубических уравнений и даже алгебраических уравнений любых степеней). Г.Лейбниц в 17 в. даже пытался найти общий алгоритм решения любых математических задач.
Уже в нашем веке эта
идея приобрела более конкретную
форму: найти алгоритм проверки правильности
любой теоремы при любой
А поскольку объектом алгоритма может оказаться все, что угодно, то начать следовало с формализации понятия объекта. Например, любые объекты реального мира можно обозначать словами в некотором алфавите. Тогда объектами действия алгоритмов могут быть только слова. В этом случае алгоритм может быть определен, как четкая конечная система правил для преобразования слов из некоторого алфавита в слова из этого же алфавита.
В начале ХХ в. алгоритм стал объектом математического изучения.
Общее понятие алгоритма
как эффективной вычислительной
процедуры и примеры
Одно из первых формальных
определений алгоритма дал
Описывая различные алгоритмы для своих машин и утверждая реализуемость всевозможных композиций алгоритмов, Тьюринг убедительно показал разнообразие возможностей предложенной им конструкции и высказал тезис: "Всякий алгоритм может быть реализован соответствующей машиной Тьюринга". Это основная гипотеза теории алгоритмов в форме Тьюринга. Одновременно этот тезис является формальным определением алгоритма.
Примерно одновременно с А.Тьюрингом английский математик Э.Пост разработал похожую, но более простую алгоритмическую схему и реализующую ее машину. Позже было предложено еще несколько общих определений понятия алгоритма, и каждый раз удавалось доказать, что, хотя новые алгоритмические схемы и выглядят иначе, они в действительности эквивалентны машинам Тьюринга: все, что реализуемо в одной из этих конструкций, можно сделать и в других.
В 1954 г. советский математик А.А. Марков[1] предложил свою алгоритмическую схему преобразования слов, назвав ее нормальным алгоритмом. Он ввел также понятие нормализации как перехода от разных способов описания алгоритмов к эквивалентным нормальным алгоритмам. Основная гипотеза теории алгоритмов в форме Маркова звучит так: "Всякий алгоритм нормализуем". Как и машина Тьюринга, алгоритмическая схема Маркова в общем случае не может быть физически реализована, т.к. она, например, допускает неограниченно большую длину слов. А вот формулировка алгоритма по Маркову: "Алгоритм - это точное предписание, которое задает вычислительный процесс, начинающийся с произвольного (но выбранного из фиксированной для данного алгоритма совокупности) исходного данного и направленный на получение полностью определяемого этим исходным данным результата" [2].
Несмотря на разные принципы построения своих теорий, все авторы алгоритмических схем старались простыми средствами обеспечить возможность описания любых алгоритмов.
Наиболее общий подход
к уточнению понятия алгоритма
предложил советский ученый Колмогоров
А.Н.[2], который дал и его "наглядное"
представление: "Алгоритм, примененный
ко всякому "условию" ("начальному
состоянию") из некоторого множества
("области применимости" алгоритма),
дает "решение" ("заключительное
состояние"). Алгоритмический процесс
расчленяется на отдельные шаги заранее
ограниченной сложности; каждый шаг состоит
в "непосредственной переработке"…
(одного) состояния в (другое). Процесс
переработки… продолжается до тех пор,
пока либо не произойдет безрезультатная
остановка, либо не появится сигнал о получении
"решения". При этом не исключается
возможность неограниченного продолжения
процесса…" Формулировка Колмогорова
содержит два существенных момента: идея итеративности алгоритмиче
С середины ХХ века стали
разрабатываться различные
В настоящее время понятие
"алгоритм" вышло за пределы
математики. Его стали применять
в самых различных областях, понимая
под ним точно сформулированные
инструкции, назначение которых - достижение
необходимого результата.
Формирование научного понятия алгоритма,
ставшее важной проблемой, не закончено
и в настоящее время. Теория алгоритмов,
как любая другая наука, находится в постоянном
развитии. Согласно утверждению авторов
[2], современная теория
алгоритмов может быть разделена на
две части.
Первая часть - это общая теория, касающаяся строения алгоритмов и исчислений самих по себе. В ней выделяются дескриптивная область (занимающаяся вопросами о наличии или отсутствии алгоритмов и исчислений, приводящих к заданной цели) и метрическая (занимающаяся оцениванием сложности процессов вычисления и порождения).
Вторая часть представляет
собой прикладную теорию, которая
имеет дело с проблемами, связанными
с понятиями алгоритма и
Понятие алгоритма является фундаментальной
категорией математики и не может
быть выражено через другие, более
простые понятия, а рассматривается
как нечто неопределяемое. Другими
словами, единого определения алгоритма
не существует, есть только разные подходы,
описания этого понятия, причем, в
полном соответствии с той областью
знаний, где он применяется. Будем
рассматривать понятие
Алгоритм - это строгая, четкая последовательность математических и логических операций, приводящая к решению задачи.
В Толковом словаре по информатике (1991г.) дано общепринятое понятие: алгоритм - точное предписание, определяющее вычислительный процесс, ведущий от варьируемых начальных данных к искомому результату.
Алгоритмизация процессов в широком смысле - это описание процессов на языке математических символов для получения алгоритма, отображающего элементарные акты процесса, их последовательность и взаимосвязь. Для построения алгоритма управления, например, необходимо к алгоритму, описывающему процесс функционирования системы, присоединить алгоритм определения оптимального решения или оптимальных значений параметров управления. В более узком смысле алгоритмизация - это процедура поиска, разработки и описания алгоритма решения задачи [5].
3. Свойства алгоритма
Описание основных свойств помогает углубить само понятие алгоритма. Итак, алгоритм должен обладать следующими свойствами: