Псевдокод

Описание алгоритма, напоминающего компьютерную программу

В информатике псевдокод — это описание шагов алгоритма с использованием смеси соглашений языков программирования (например, оператор присваивания , условный оператор , цикл ) с неформальной, обычно понятной, нотацией действий и условий. [1] [2] Хотя псевдокод разделяет черты с обычными языками программирования , он предназначен для чтения человеком , а не для машинного управления. Псевдокод обычно опускает детали, которые необходимы для машинной реализации алгоритма, что означает, что псевдокод можно проверить только вручную. [3] Язык программирования дополняется подробностями описания естественного языка , где это удобно, или компактной математической нотацией . Цель использования псевдокода заключается в том, что его легче понять людям, чем код обычного языка программирования, и что он является эффективным и независимым от среды описанием ключевых принципов алгоритма. Он обычно используется в учебниках и научных публикациях для документирования алгоритмов и при планировании программного обеспечения и других алгоритмов.

Не существует широкого стандарта для синтаксиса псевдокода , поскольку программа на псевдокоде не является исполняемой программой; однако существуют определенные ограниченные стандарты (например, для академической оценки). Псевдокод напоминает скелетные программы , которые могут быть скомпилированы без ошибок. Блок-схемы , drakon-charts и диаграммы Unified Modeling Language (UML) можно рассматривать как графическую альтернативу псевдокоду, но для них требуется больше места на бумаге. Такие языки, как HAGGIS, заполняют разрыв между псевдокодом и кодом, написанным на языках программирования.

Приложение

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

Программист , которому необходимо реализовать определенный алгоритм, особенно незнакомый, часто начинает с описания псевдокода, а затем «переводит» это описание на целевой язык программирования и изменяет его для корректного взаимодействия с остальной частью программы. Программисты также могут начать проект, набросав код в псевдокоде на бумаге, прежде чем писать его на реальном языке, как подход структурирования сверху вниз , с процессом шагов, которым нужно следовать в качестве уточнения.

Псевдокод также используется в стандартизации. Например, стандарты MPEG широко используют формальный псевдокод типа C и не могут быть поняты без понимания деталей кода. [4]

Синтаксис

Псевдокод, как правило, на самом деле не подчиняется правилам синтаксиса какого-либо конкретного языка; систематической стандартной формы не существует. Некоторые авторы заимствуют стиль и синтаксис из управляющих структур некоторых традиционных языков программирования, хотя это не приветствуется. [5] [6] Некоторые источники синтаксиса включают Fortran , Pascal , BASIC , C , C++ , Java , Lisp и ALGOL . Объявления переменных обычно опускаются. Вызовы функций и блоки кода, такие как код, содержащийся в цикле, часто заменяются однострочным предложением на естественном языке.

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

Такая гибкость имеет как основные преимущества, так и недостатки: с положительной стороны, ни один исполняемый язык программирования «не может сравниться с удобством изобретения новых конструкций по мере необходимости и предоставления читателю возможности попытаться вывести их значение из неформальных объяснений», с отрицательной стороны, «непроверенный код обычно неверен» [7] .

Пример псевдокода (для математической игры fizz buzz )

Стиль Паскаля:

procedure fizzbuzz ; for i : = 1 to 100 do print_number : = true ; if i делится на 3 then begin print " Fizz " ; print_number : = false ; end ; if print_number , print i ; print a new line ; end                                               

Стиль С:

fizzbuzz () { for ( i = 1 ; i < = 100 ; i ++ ) { print_number = true ; if ( i делится на 3 ) { print "Fizz" ; print_number = false ; } if ( i делится на 5 ) { print "Buzz" ; print_number = false ; } if ( print_number ) print i ; print a new line ; } }                                               

Стиль Python:

def  fizzbuzz ( ) :  for  i  in  range ( 1 , 101 ):  print_number  =  true  если  i  делится  на  3 : print "Fizz" print_number = false если i делится на 5 : print "Buzz" print_number = false если print_number : print i печатает новую строку                        

Псевдокод в математическом стиле

В числовых вычислениях псевдокод часто состоит из математической нотации , как правило, из теории матриц и множеств , смешанной с управляющими структурами обычного языка программирования, а также, возможно, описаниями на естественном языке . Это компактная и часто неформальная нотация, понятная широкому кругу людей с математической подготовкой, и часто используемая как способ описания математических алгоритмов . Например, оператор суммы ( нотация с заглавной буквой «сигма» ) или оператор произведения ( нотация с заглавной буквой «пи» ) могут представлять цикл for и структуру выбора в одном выражении:

Возвращаться       k  S    x  k     {\displaystyle \sum _{k\in S}x_{k}} 

Обычно для математических уравнений используется не- ASCII набор текста , например, с помощью языков разметки, таких как TeX или MathML , или фирменных редакторов формул .

Псевдокод в математическом стиле иногда называют пиджин-кодом , например, пиджин АЛГОЛ (происхождение концепции), пиджин Фортран , пиджин БЕЙСИК , пиджин Паскаль , пиджин С и пиджин Лисп .

Общие математические символы

Тип операцииСимволПример
Назначение← или :=c ← 2πr, c := 2πr
Сравнение=, ≠, <, >, ≤, ≥
Арифметика+, −, ×, /, мод
Пол/потолок⌊, ⌋, ⌈, ⌉a ← ⌊b⌋ + ⌈c
Логичныйи , или
Суммы, произведенияΣ Пh ← ΣaA 1/a

Пример

Ниже приведен более длинный пример псевдокода в математическом стиле для алгоритма Форда–Фалкерсона :

Входные данные  алгоритма Форда-Фулкерсона : График G с пропускной способностью c , исходный узел s , Выход приемного узла t  : Поток f такой, что f максимален от s до t (Обратите внимание, что f (u,v) — это поток из узла u в узел v, а c (u,v) — это пропускная способность потока из узла u в узел v) для каждого ребра ( u , v ) в  G E  сделать  f ( u , v ) ← 0 f ( v , u ) ← ​​0 в то время как существует путь p из s в t  в остаточной сети G f  do пусть c f будет пропускной способностью остаточной сети G f  c f ( p ) ← min{ c f ( u , v ) | ( u , v ) в  p } для каждого ребра ( u , v ) в  p  do  f ( u , v )f ( u , v ) + c f ( p ) f ( v , u ) ← − f ( u , v ) возвращение  ф

Машинная компиляция языков псевдокодового стиля

Грамматика естественного языка в языках программирования

Различные попытки привнести элементы грамматики естественного языка в компьютерное программирование привели к появлению таких языков программирования, как HyperTalk , Lingo , AppleScript , SQL , Inform и, в некоторой степени, Python . В этих языках скобки и другие специальные символы заменяются предлогами, что приводит к довольно многословному коду. Эти языки, как правило, динамически типизированы , что означает, что объявления переменных и другой шаблонный код могут быть опущены. Такие языки могут облегчить человеку, не имеющему знаний о языке, понимание кода и, возможно, также изучение языка. Однако сходство с естественным языком обычно скорее косметическое, чем подлинное. Правила синтаксиса могут быть такими же строгими и формальными, как и в обычном программировании, и не обязательно упрощают разработку программ.

Математические языки программирования

Альтернативой использованию математического псевдокода (включая нотацию теории множеств или матричные операции) для документирования алгоритмов является использование формального математического языка программирования, который представляет собой смесь математической нотации, отличной от ASCII, и структур управления программой. Затем код может быть проанализирован и интерпретирован машиной.

Несколько формальных языков спецификации включают нотацию теории множеств с использованием специальных символов. Примеры:

Некоторые языки программирования массивов включают векторизованные выражения и матричные операции как не-ASCII формулы, смешанные с обычными управляющими структурами. Примеры:

Смотрите также

Ссылки

  1. ^ Рейсиг 2007, стр. 23, Программы на псевдокодах и их семантика.
  2. ^ Часто повторяемое определение псевдокода, по крайней мере с 2003 года, — это «подробное, но читаемое описание того, что должна делать компьютерная программа или алгоритм, выраженное на формально оформленном естественном языке».
  3. ^ Ulate-Caballero, Bryan Alexander; Berrocal-Rojas, Allan; Hidalgo-Céspedes, Jeisson (2021). «Concurrent and Distributed Pseudocode: A Systematic Literature Review». 2021 XLVII Latin American Computing Conference (CLEI) . стр. 1–10. doi : 10.1109/CLEI53233.2021.9640222. ISBN 978-1-6654-9503-5.
  4. ^ Митчелл и др. 1996, стр. 105.
  5. ^ Макконнелл, Стив (2004). Code Complete . Pearson Education. стр. 54. ISBN 978-0-7356-1967-8. Избегайте синтаксических элементов из целевого языка программирования.
  6. ^ Приглашение в Computer Science, 8-е издание Шнайдера/ Герстинга , «Сохраняйте независимость утверждений от языка», как процитировано в этом вопросе StackExchange
  7. ^ Лампорт, Лесли (2 января 2009 г.). «Язык алгоритмов PlusCal» (PDF) . Microsoft Research . Получено 28 мая 2024 г. .

Дальнейшее чтение

  • Zobel, Джастин (2013). «Алгоритмы». Writing for Computer Science (Второе изд.). Springer. ISBN 978-1-85233-802-2.
  • Рой, Джеффри Г. (2006). «Проектирование и объяснение программ с помощью грамотного псевдокода». Журнал образовательных ресурсов по вычислительной технике . 6 (1). Ассоциация вычислительной техники (ACM): 1. doi :10.1145/1217862.1217863. ISSN  1531-4278. S2CID  25810599.
  • Ulate-Caballero, Bryan Alexander; Berrocal-Rojas, Allan; Hidalgo-Cespedes, Jeisson (2021-10-25). "Concurrent and Distributed Pseudocode: A Systematic Literature Review". XLVII Latin American Computing Conference (CLEI) 2021 г. IEEE. стр. 1–10. doi :10.1109/clei53233.2021.9640222. ISBN 978-1-6654-9503-5.
  • Рейзиг, Вольфганг (2007). «Абстрактные машины состояний для классной комнаты». Логика языков спецификаций . Монографии по теоретической информатике. Серия EATCS. ​​Springer Berlin Heidelberg. С. 15–46. ISBN 978-3-540-74107-7. Получено 2023-10-05 .
  • Митчелл, Джоан Л.; Пеннебейкер, Уильям Б.; Фогг, Чад Э.; ЛеГалл, Дидье Дж. (1996). «Псевдокод и блок-схемы». Стандарт сжатия видео MPEG . Нью-Йорк, Нью-Йорк: Springer US. стр. 105–116. doi :10.1007/0-306-46983-9_6. ISBN 978-0-412-08771-4.
  • Беллами, Рэйчел (1994-06-01). «Что делает псевдокод? Психологический анализ использования псевдокода опытными программистами». Взаимодействие человека и компьютера . 9 (2). Informa UK Limited: 225–246. doi :10.1207/s15327051hci0902_3. ISSN  0737-0024.
  • Стандарт псевдокода
  • Собранные алгоритмы ACM
  • Руководство по псевдокоду, файл PDF.
Retrieved from "https://en.wikipedia.org/w/index.php?title=Pseudocode&oldid=1239902998"