Студопедия

КАТЕГОРИИ:


Архитектура-(3434)Астрономия-(809)Биология-(7483)Биотехнологии-(1457)Военное дело-(14632)Высокие технологии-(1363)География-(913)Геология-(1438)Государство-(451)Демография-(1065)Дом-(47672)Журналистика и СМИ-(912)Изобретательство-(14524)Иностранные языки-(4268)Информатика-(17799)Искусство-(1338)История-(13644)Компьютеры-(11121)Косметика-(55)Кулинария-(373)Культура-(8427)Лингвистика-(374)Литература-(1642)Маркетинг-(23702)Математика-(16968)Машиностроение-(1700)Медицина-(12668)Менеджмент-(24684)Механика-(15423)Науковедение-(506)Образование-(11852)Охрана труда-(3308)Педагогика-(5571)Полиграфия-(1312)Политика-(7869)Право-(5454)Приборостроение-(1369)Программирование-(2801)Производство-(97182)Промышленность-(8706)Психология-(18388)Религия-(3217)Связь-(10668)Сельское хозяйство-(299)Социология-(6455)Спорт-(42831)Строительство-(4793)Торговля-(5050)Транспорт-(2929)Туризм-(1568)Физика-(3942)Философия-(17015)Финансы-(26596)Химия-(22929)Экология-(12095)Экономика-(9961)Электроника-(8441)Электротехника-(4623)Энергетика-(12629)Юриспруденция-(1492)Ядерная техника-(1748)

Свойства алгоритма




Алгоритм и программа

ОСНОВЫ АЛГОРИТМИЗАЦИИ

ВВЕДЕНИЕ

 

Наиболее важными вехами последних 15-20 лет в создании программ на языках высокого уровня являются методологии структурного и объектно-ориентированного программирования. Параллельно с ними сравнительно давно используется метод «автоматного» программирования, позволяющий в основу проектирования программы заложить алгоритм – конечный автомат в виде диаграммы состояний или таблицы последовательных переходов и выходов. В отличие от традиционных алгоритмов, включающих два вида компонент: условие и действие, конечный автомат дополнительно включает такую компоненту, как состояние.

На сегодня доминирующим языком программирования, без сомнения, является язык Си++. Это объясняется тем, что любой код, написанный на Си, чрезвычайно гибкий и легко переносится на различные платформы. В Си и Си++ входит много полезных особенностей – простота, объектная ориентированность и многое другое. Ввиду своего очень удобного объектно-ориентированного дизайна, данные языки являются хорошим выбором для быстрого конструирования различных компонентов – от высокоуровневой бизнес-логики до системных приложений, использующих низкоуровневый код.

Четкие границы между Си и Си++ в пособии не проводились, поскольку для начального освоения этого языка условности, связанные с разграничением, не являются столь необходимыми. Если нет специальных оговорок, будем подразумевать язык Си. При использовании специфических функций Си++ это будет оговариваться особо.

 

 

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

Совокупность средств и правил для представления алгоритма в виде, пригодном для выполнения вычислительной машиной, называется языком программирования, а алгоритм, записанный на этом языке, называется программой.

Сначала всегда разрабатывается алгоритм действий, а потом он записывается на одном из языков программирования. Текст программы обрабатывается специальными служебными программами – трансляторами. Языки программирования – это искусственные языки. От естественных языков они отличаются ограниченным числом «слов» и очень строгими правилами записи команд (операторов). Совокупность этих требований образует синтаксис языка программирования, а смысл каждой конструкции – его семантику.

 

1. Массовость: алгоритм должен применяться не к одной задаче, а к целому классу подобных задач (алгоритм для решения квадратного уравнения должен решать не одно уравнение, а все квадратные уравнения).

2. Результативность: алгоритм должен приводить к получению результата за конкретное число шагов (при делении 1 на 3 получается периодическая дробь 0,3333(3), для достижения конечного результата надо оговорить точность получения этой дроби, например, до 4 знака после запятой).

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

4. Дискретность – процесс должен быть описан с помощью неделимых операций, выполняемых на каждом шаге (т. е. шаги нельзя разделить на более мелкие шаги).

Алгоритмы можно представить в следующих формах:

1) словесное описание алгоритма,

2) графическое описание алгоритма,

3) с помощью алгоритмического языка программирования.

 




Поделиться с друзьями:


Дата добавления: 2015-06-04; Просмотров: 318; Нарушение авторских прав?; Мы поможем в написании вашей работы!


Нам важно ваше мнение! Был ли полезен опубликованный материал? Да | Нет



studopedia.su - Студопедия (2013 - 2024) год. Все материалы представленные на сайте исключительно с целью ознакомления читателями и не преследуют коммерческих целей или нарушение авторских прав! Последнее добавление




Генерация страницы за: 0.009 сек.