튜링 머신 소개

Turing Machine은 유형 0 문법에 의해 생성 된 언어 (재귀 적으로 열거 가능한 집합)를 받아들이는 장치입니다. Alan Turing이 1936 년에 발명했습니다.

정의

Turing Machine (TM)은 입력이 제공되는 셀로 분할 된 무한 길이 테이프로 구성된 수학적 모델입니다. 입력 테이프를 읽는 헤드로 구성됩니다. 상태 레지스터는 튜링 머신의 상태를 저장합니다. 입력 기호를 읽은 후 다른 기호로 대체되고 내부 상태가 변경되며 한 셀에서 오른쪽 또는 왼쪽으로 이동합니다. TM이 최종 상태에 도달하면 입력 문자열이 승인되고 그렇지 않으면 거부됩니다.

TM은 공식적으로 7- 튜플 (Q, X, ∑, δ, q 0 , B, F)로 설명 할 수 있습니다.

  • Q 유한 한 상태 집합입니다.

  • X 테이프 알파벳입니다

  • 입력 알파벳입니다.

  • δ전환 함수입니다. δ : Q × X → Q × X × {Left_shift, Right_shift}.

  • q0 초기 상태입니다.

  • B 빈 기호입니다.

  • F 최종 상태 집합입니다.

이전 오토 마톤과의 비교

다음 표는 튜링 머신이 유한 오토 마톤 및 푸시 다운 오토 마톤과 어떻게 다른지 비교 한 것입니다.

기계 스택 데이터 구조 결정 론적?
유한 오토 마톤 NA
푸시 다운 오토 마톤 후입 선출 (LIFO) 아니
튜링 머신 무한 테이프

튜링 머신의 예

튜링 머신 M = (Q, X, ∑, δ, q 0 , B, F)

  • Q = {q 0 , q 1 , q 2 , q f }
  • X = {a, b}
  • ∑ = {1}
  • q 0 = {q 0 }
  • B = 공백 기호
  • F = {q f }

δ는 −

테이프 알파벳 기호 현재 상태 'q 0 ' 현재 상태 'q 1 ' 현재 상태 'q 2 '
1Rq 1 1Lq 0 1Lq f
1Lq 2 1Rq 1 1Rq f

여기서 1Rq 1 전이 는 쓰기 기호가 1이고 테이프가 오른쪽으로 이동하며 다음 상태가 q 1 임을 의미합니다 . 마찬가지로 전환 1Lq 2 는 쓰기 기호가 1이고 테이프가 왼쪽으로 이동하며 다음 상태가 q 2 임을 의미합니다 .

튜링 머신의 시간 및 공간 복잡성

Turing 기계의 경우 시간 복잡도는 기계가 일부 입력 기호에 대해 초기화 될 때 테이프가 이동하는 횟수의 척도를 나타내며 공간 복잡도는 기록 된 테이프의 셀 수입니다.

모든 합리적인 기능의 시간 복잡성-

T(n) = O(n log n)

TM의 공간 복잡성-

S(n) = O(n)