📅  最后修改于: 2020-12-17 07:55:38             🧑  作者: Mango
图灵机由艾伦·图灵(Alan Turing)于1936年发明。它是一种接受设备,它接受由类型0语法生成的递归可枚举语言。
图灵机具有多种功能:
图灵机可以定义为7个组件的集合:
Q :有限状态集
∑ :输入符号的有限集
T :磁带符号
q0 :初始状态
F :一组最终状态
B :用作输入结束标记的空白符号
δ :过渡或映射函数。
映射函数显示从有限自动机的状态和磁带上的输入符号到下一个状态,外部符号和磁带头移动方向的映射。这被称为三重奏或图灵机程序。
(q0, a) → (q1, A, R)
这意味着在q0状态下,如果我们读取符号'a',它将进入状态q1,用X代替a并向右移动(R代表右)。
为语言L = {0 n 1 n }构造TM,其中n> = 1。
解:
我们已经通过PDA解决了这个问题。在PDA中,我们有一个堆栈来记住先前的符号。图灵机的主要优点是我们有一个可以向前或向后移动的磁带头,并且可以扫描输入的磁带。
我们将应用的简单逻辑是,读出A标记的每个“ 0”,然后与输入带一起向前移动,找出1将其转换为B。现在,对所有a和b重复此过程。
现在,我们将看到该图灵机在0011上的工作方式。
现在,我们将看到该图灵机如何在0011上运行。最初,状态为q0,并且将head指向0的情况是:
该移动将为δ(q0,0)=δ(q1,A,R),这意味着它将进入状态q1,将0替换为A,并且头部将向右移动为:
该移动将为δ(q1,0)=δ(q1,0,R),这意味着它将不会更改任何符号,而是保持相同的状态并向右移动,如下所示:
该移动将为δ(q1,1)=δ(q2,B,L),这意味着它将进入状态q2,由B代替1,并且头部将向左移动为:
现在,移动将为δ(q2,0)=δ(q2,0,L),这意味着它将不会更改任何符号,而是保持相同的状态并向左移动:
该移动将为δ(q2,A)=δ(q0,A,R),这意味着将进入状态q0,将A替换为A,头部将向右移动为:
该移动将为δ(q0,0)=δ(q1,A,R),这意味着它将进入状态q1,将0替换为A,并且磁头将向右移动为:
移动将为δ(q1,B)=δ(q1,B,R),这意味着它将不会更改任何符号,而是保持相同的状态并向右移动,如下所示:
该移动将为δ(q1,1)=δ(q2,B,L),这意味着它将进入状态q2,由B代替1,并且头部将向左移动为:
移动δ(q2,B)=(q2,B,L)表示它不会更改任何符号,保持相同状态并向左移动,如下所示:
现在,紧接在B之前的是A,这意味着所有0都由A卖出。因此,我们将继续执行以确保不存在1。移动将为δ(q2,A)=(q0,A,R),这意味着它将进入状态q0,将不更改任何符号,并向右移动为:
移动δ(q0,B)=(q3,B,R),这意味着它将进入状态q3,不会更改任何符号,并且向右移动为:
移动δ(q3,B)=(q3,B,R)表示它不会更改任何符号,而是保持相同的状态并向右移动,如下所示:
移动δ(q3,Δ)=(q4,Δ,R)表示将进入状态q4,这是HALT状态,而HALT状态始终是任何TM的接受状态。
相同的TM可以用过渡图表示: