Студопедия

КАТЕГОРИИ:


Архитектура-(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)

Двоичное дерево




 

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

Для перехода от дерева разбора к его двоичному эквиваленту следует воспользоваться следующими правилами:

правило формирования левого поддерева: если вершина "K" является самым левым потомком вершины "J" в дереве разбора, то эта вершина формирует вершину-сток левого поддерева двоичного дерева и является левым потомком вершины "J" двоичного дерева; вершина-исток левого поддерева есть образ символа, находящегося в левой части правила грамматики, а вершина-сток - образ первого символа правой части правила грамматики;

правило формирования правого поддерева: если вершина "L" является старшим среди оставшихся (после удаления вершины "K" для формирования левого поддерева) братьев - потомков вершины "J" в дереве разбора, то эта вершина формирует вершину-сток правого поддерева двоичного дерева и является правым потомком старшего брата - вершины "K"; все последующие братья - потомки вершины "J" в дереве разбора являются правыми потомками братьев по старшинству и формируют правые поддеревья двоичного дерева; вершина-исток правого поддерева есть образ предшествующего левого символа в правой части правила, а вершина-сток - образ следующего справа символа в правой части правила

Пусть дано правило J::=KLM,

где J, K,L,M, Î VN.

На рис.14а) представлен граф двоичного дерева. В составе этого дерева - одно левое поддерево, соединяющее вершины J и K и два правых, соединяющих вершины K и L, L и M.

Пусть дано множество правил КС-грамматики:

J::= KLM, K::= k и L::= Pm,

где k,m Î VT,

J,K,L,M,P Î VN.

На рис. 14b) представлен граф двоичного дерева. В составе этого дерева три левых поддерева, соединяющих вершины J и K, K и k, L и P и три правых поддерева,соединяющих вершины K и L, L и M, Р и m.

 

Рассмотрим двоичные деревья для синтаксических деревьев и деревьев разбора, представленных в примерах 20, 21, 22 и 23.

Пример 30. Для синтаксического дерева, представленного на рис. 6, сформировать двоичное дерево.

На рис.15 представлен двоичный эквивалент дерева разбора в соответствии с правилами грамматики, заданными в примере 20.

 

 

 

 

Пример 31. Для дерева разбора синтаксической переменной <программа> языка программирования Паскаль, представленного в примере 21 (рис. 7), сформировать двоичное дерево.

На рис.16 представлен двоичный эквивалент дерева разбора в соответствии с правилами грамматики, заданными в 2 (пример 1).

Пример 32. Для дерева разбора синтаксической переменной <выражение> языка программирования Паскаль, представленного в примере 22 (рис. 8), сформировать двоичное дерево.

На рис.17 представлен двоичный эквивалент дерева разбора в соответствии с правилами грамматики, заданными в 2 (пример 1).

Пример 33. Для синтаксических деревьев арифметических выражений:

a) J = a +b2, b) J = a2 + b2,

c) J = (a + b)2 d)J = a x b + a(a - b)

в грамматике G9, рассмотренных в примере 23 (рис. 9,10,11,12), сформировать двоичные деревья.

На рис.18, 19, 20 и 21 представлены двоичные эквиваленты синтаксических деревьев по правилам грамматики, заданными в 3 (пример 14).

 

 




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


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


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



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




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