문맥없는 문법 소개

Definition − 유한 한 문법 규칙 집합으로 구성된 CFG (Context-free grammar)는 4 배입니다. (N, T, P, S) 어디

  • N 비 터미널 기호 세트입니다.

  • T 터미널 세트입니다. N ∩ T = NULL.

  • P 일련의 규칙입니다. P: N → (N ∪ T)*즉, 생산 규칙의 왼쪽 P 오른쪽 컨텍스트 또는 왼쪽 컨텍스트가 있습니다.

  • S 시작 기호입니다.

Example

  • 문법 ({A}, {a, b, c}, P, A), P : A → aA, A → abc.
  • 문법 ({S, a, b}, {a, b}, P, S), P : S → aSa, S → bSb, S → ε
  • 문법 ({S, F}, {0, 1}, P, S), P : S → 00S | 11F, F → 00F | ε

파생 트리 생성

파생 트리 또는 구문 분석 트리는 컨텍스트 프리 문법에서 파생 된 문자열의 의미 정보를 그래픽으로 나타내는 정렬 된 루트 트리입니다.

표현 기법

  • Root vertex − 시작 기호로 레이블을 지정해야합니다.

  • Vertex − 비 터미널 기호로 레이블이 지정됩니다.

  • Leaves − 터미널 기호 또는 ε으로 표시됩니다.

S → x 1 x 2 …… x n 이 CFG의 생산 규칙이면 파스 트리 / 유도 트리는 다음과 같습니다.

파생 트리를 그리는 방법에는 두 가지가 있습니다.

Top-down Approach −

  • 시작 기호로 시작 S

  • 프로덕션을 사용하여 나무 잎으로 내려갑니다.

Bottom-up Approach −

  • 나무 잎에서 시작

  • 시작 기호 인 루트까지 위쪽으로 진행합니다. S

나무의 파생 또는 수확

파스 트리의 파생 또는 산출은 Null을 무시하고 트리 잎의 레이블을 왼쪽에서 오른쪽으로 연결하여 얻은 최종 문자열입니다. 그러나 모든 잎이 Null이면 파생은 Null입니다.

Example

CFG {N, T, P, S}를

N = {S}, T = {a, b}, 시작 기호 = S, P = S → SS | aSb | ε

위의 CFG에서 파생 된 하나는 "abaabb"입니다.

S → SS → aSbS → abS → abaSb → abaaSbb → abaabb

문장 양식 및 부분 파생 트리

부분 파생 트리는 파생 트리 / 구문 분석 트리의 하위 트리로 모든 하위 트리에 하위 트리에 있거나 하위 트리에 아무것도 없습니다.

Example

CFG에서 제작물이-

S → AB, A → aaA | ε, B → Bb | ε

부분 파생 트리는 다음과 같습니다.

부분 파생 트리에 루트 S가 포함 된 경우이를 sentential form. 위의 하위 트리도 감각적 형식입니다.

문자열의 맨 왼쪽 및 맨 오른쪽 파생

  • Leftmost derivation − 각 단계에서 가장 왼쪽의 변수에 생산을 적용하여 가장 왼쪽의 도출을 얻습니다.

  • Rightmost derivation − 각 단계에서 가장 오른쪽 변수에 생산을 적용하여 가장 오른쪽에 파생 된 값을 얻습니다.

Example

CFG의 모든 생산 규칙 세트를

X → X + X | X * X | X | ㅏ

알파벳 {a} 이상.

문자열의 가장 왼쪽 파생 "a+a*a" 아마도-

X → X + X → a + X → a + X * X → a + a * X → a + a * a

위 문자열의 단계적 파생은 다음과 같습니다.

위의 문자열에 대한 가장 오른쪽 파생 "a+a*a" 아마도-

X → X * X → X * a → X + X * a → X + a * a → a + a * a

위 문자열의 단계적 파생은 다음과 같습니다.

왼쪽 및 오른쪽 재귀 문법

문맥없는 문법 G, 형태로 제작이있는 경우 X → Xa 어디 X 비 터미널이고 ‘a’ 터미널의 문자열이며, left recursive production. 왼쪽 재귀 생성을 갖는 문법을left recursive grammar.

그리고 문맥없는 문법에서 G, 생산이있는 경우 형태로 X → aX 어디 X 비 터미널이고 ‘a’ 터미널의 문자열이며, right recursive production. 올바른 재귀 생성을 갖는 문법을right recursive grammar.