求助:编写一个程序,输入一个文法,输出其正则表达式。

zhangzhiq000 2008-06-29 01:00:18
求助:编写一个程序,输入一个文法,输出其正则表达式。收藏
例如 文法L={Q,T,P,S}
P:
输入包括三部分:非终结符Q,终结符 T,生成式P,起始符可要可不要。
例:
S
a,b

S->aS;
S->b;
输出:
a*b(注释:a*b表示n个a后面接上一个b,其中n>=0,输出并不一定要上述格式,只需要能看懂的输出就行)
...全文
347 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
IT_lau 2008-06-30
  • 打赏
  • 举报
回复
gz
GoAssemblyNow 2008-06-30
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 baihacker 的回复:]
这个难度大啊...
等高手出现.
[/Quote]
飞雪好谦虚!
two_ears 2008-06-29
  • 打赏
  • 举报
回复
m
zhangzhiq000 2008-06-29
  • 打赏
  • 举报
回复
用方程来求解就是把文法通过代换得到 A->bA+c;这样由公式就可以得到正则文法b* C么,好的,谢谢,我试试~~~
zhangzhiq000 2008-06-29
  • 打赏
  • 举报
回复
不好意思,可能没讲清楚,输入文法保证是右线性文法,这样就保证有正则表达式,然后输出其正则表达式。
crushor 2008-06-29
  • 打赏
  • 举报
回复
你的文法是指什么?
如果是指规则的话,你的文法本身不就是正则表达式?无非是换了种符号而已.
zyw052553 2008-06-29
  • 打赏
  • 举报
回复
你这问的有问题
不是任何文法都有对应的正则表达式
若改为正规文法的话,可用解方程的方式求解
baihacker 2008-06-29
  • 打赏
  • 举报
回复
这个难度大啊...
等高手出现.

64,683

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧