编译原理期末复习题总结

1.试描述下列正则表达式定义的语言

  1. a(a|b)*a
  2. ((ε|a)b*)*
  3. (a|b)*a(a|b)(a|b)
  4. a*ba*ba*ba*
  5. (aa|bb)*((ab|ba)(aa|bb)*(ab|ba)(aa|bb)*)*
    答案:
    (1) a(a|b)*a :以 a开头以 a结束的由字母 a和 b 组成字符串
    (2) ((ε|a)b*)* :由字母 a或 b 组成字符串。
    (3) (a|b)*a(a|b)(a|b) :由字母 a和 b 组成的字符串,其倒数第三个字母为 a。
    (4) a*ba*ba*ba* :由字母 a和 b 组成的字符串,整个串包含且仅包含 3 个 b
    (5) (aa|bb)*((ab|ba)(aa|bb)*(ab|ba)(aa|bb)*)* :包含偶数个 a和 b 的字符串。

2.给出下列语言的正则表达式

(1) 包含 5 个元音字母(a, e, i, o, u)的所有小写英文字母串,这些串中的元音按顺序出现。
(2) 所有按字典递增序排列的小写字母组成的串。
(3) 所有由 a和 b 组成且不含有子串 abb 的串
(4) 所有由 a和 b 组成且不含有子序列 abb 的串
答案:
在这里插入图片描述

3.给出识别下列各正则表达式所描述语言的状态转换图

  1. a(a|b)*a
  2. ((ε|a)b*)*
  3. (a|b)*a(a|b)(a|b)
  4. a*ba*ba*ba

在这里插入图片描述
在这里插入图片描述
3)(a|b)*a(a|b)(a|b)
在这里插入图片描述
在这里插入图片描述

4、为下列各正则表达式设计相应的 NFA,并分别转换成 DFA

  1. (a|b)*
  2. (a*|b*)*
  3. a(a|b)*a
  4. ((ε|a)b*)*
  5. (a|b)*abb(a|b)*
    (1)

在这里插入图片描述

在这里插入图片描述

  • 11
    点赞
  • 99
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

只会写bug的菜鸟

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值