免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2732 | 回复: 8
打印 上一主题 下一主题

[算法] 一个文法的算法设计小问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-07-17 14:51 |只看该作者 |倒序浏览
20可用积分
问题:
1. 需要得到{a^nb^nc^n|n>=0}这样的字符串,怎么用一个最简单的形式文法来表示它的生成过程?
2. 假如我有aaaabbbcc,编程输出这个字符串的文法分析的过程,大概需要什么样子的思路呢?

是不是需要弄一个状态机来分析它? 请大人指点一下,谢谢!

最佳答案

查看完整内容

{a^nb^nc^n|n>=0},这个不能用上下文无关文法来描述,但可以用下面的乔姆斯基1型文法(Context-sensitive grammar)生成:S->aBScS->abcBa->aBBb->bbps:楼主干什么项目的啊,居然要用到这些东西。在下很好奇[ 本帖最后由 gta 于 2009-7-17 20:58 编辑 ]

论坛徽章:
0
2 [报告]
发表于 2009-07-17 14:51 |只看该作者
{a^nb^nc^n|n>=0},这个不能用上下文无关文法来描述,但可以用下面的乔姆斯基1型文法(Context-sensitive grammar)生成:

S->aBSc
S->abc
Ba->aB
Bb->bb



ps:楼主干什么项目的啊,居然要用到这些东西。在下很好奇

[ 本帖最后由 gta 于 2009-7-17 20:58 编辑 ]

论坛徽章:
0
3 [报告]
发表于 2009-07-17 15:43 |只看该作者
这个很难,你可以参考下逆向工程

论坛徽章:
0
4 [报告]
发表于 2009-07-17 19:14 |只看该作者
帮顶一下,可惜我水平太低,帮不了忙,连问题都没看懂

论坛徽章:
0
5 [报告]
发表于 2009-07-17 19:45 |只看该作者
是不说正则表达式引擎的实现? 龙书上讲的很详细. 词法分析那一章.

论坛徽章:
0
6 [报告]
发表于 2009-07-20 14:04 |只看该作者

回复 #1 jeanlove 的帖子

先写上下文无关文法,然后用有穷自动机进行分析,很简单

论坛徽章:
3
2015年迎新春徽章
日期:2015-03-04 09:56:11数据库技术版块每日发帖之星
日期:2016-08-03 06:20:00数据库技术版块每日发帖之星
日期:2016-08-04 06:20:00
7 [报告]
发表于 2009-07-21 14:12 |只看该作者
很多计算理论课程会拿第一种语言作为例子,它是典型的1类语言,并非由上下文无关文法,乃上下文相关文法生成.
S->aBSc
S->abc
S->
Ba->aB
Bb->bb
以上的文法因为并非2类文法,所以对你的分析作用可能不大.倒不如a^nb^nc^n来的简单

论坛徽章:
1
天蝎座
日期:2013-10-23 21:11:03
8 [报告]
发表于 2009-07-21 14:34 |只看该作者
有本书《代码之美》,好像第一个讲的就是正则表达式的识别
LZ可以看看
网上有下载,但是不全,不过第一章构了

论坛徽章:
0
9 [报告]
发表于 2009-07-22 16:53 |只看该作者
原帖由 aaaaa5aa 于 2009-7-17 15:43 发表
这个很难,你可以参考下逆向工程

和逆向工程有关系吗?这应该是属于编译原理范围内的东西。我原来编译原理学的很好,现在都忘记了,悲哀啊!
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP