微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

使用固定状态下推自动机

如何解决使用固定状态下推自动机

我被要求在字母表 {a,b,c,d} 上找到语言 L 的 PDA,其中 L={(a^p)(b^2p)(c^r) (d^s)| p,r,s > 0 AND r=s} 我已经使用 5 个状态解决了它,但我必须使用 6 个状态解决它。有人可以帮我解决吗? [1]:https://i.stack.imgur.com/pqYMQ.jpg

解决方法

带上您的 5 态 PDA。让我们将其起始状态称为 q0。构造一个新的 6 态 PDA 如下:

  1. 为您的 5 状态 PDA 添加一个新的起始状态 q*;所以,q0在新构建的PDA中仍然是一个状态,但不再是一个开始状态。

  2. 添加从 q* 到 q0 的转换,它要求栈底符号 Z0 位于栈顶(即栈为空)并且不消耗任何输入(epsilon/lambda过渡)。

您现在拥有一个 6 状态 PDA,它接受与您的 5 状态 PDA 完全相同的语言。

更简单:添加一个新状态,该状态在所有可能的堆栈/输入组合上转换到自身,并且在 5 状态 PDA 中没有其他状态转换到。这将生成一个 6 状态 PDA,它接受与 5 状态 PDA 相同的语言。当然,状态图现在已断开连接,但我不确定通过转换连接的状态图是否真的是自动机标准定义中的要求。当然,添加从开始状态无法到达的状态是愚蠢的,但是当您拥有完美的 5 态 PDA 时,坚持 6 态 PDA 也是愚蠢的。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?