(线性)[问题描述]有一个魔王总是使用自己的一种非常精练而又抽象的语言讲话,没有人能听得懂,但他的语言是可以逐步解释成人能听懂的语言,因为他的语言是由以下两种形式的规则由人的语言逐步抽象上去的:(1)α->β1β2…βm(2)(θδ1δ2…δn)->θδnθδn-1…θδ1θ在这两种形式中,从左到右均表示解释。试写一个魔王语言的解释系统,把他的话解释成人能听得懂的话。[基本要求]用下述两条具体规则和上述规则形式(2)实现。设大写字母表示魔王语言的词汇;小写字母表示人的语言词汇;希腊字母表示可以用大写字母或小写字母代换的变量。魔王语言可含人的词汇。(1)B->tAdA(2)A->sae[测试数据]B(ehnxgz)B解释成tsaedsaeezegexenehetsaedsae若将小写字母与汉字建立下表所示的对应关系,则魔王说的话是:“天上一只鹅地上一只鹅鹅追鹅赶鹅下鹅蛋鹅恨鹅天上一只鹅地上一只鹅”。tdsaezgxnh天地上一只鹅追赶下蛋恨一:需求分析(1)以一维数组demon[i]表示魔王语言.(2)魔王语言由用户输入,初始保存在demon[i]中.(3)魔王语言与人类语言对应关系固化在程序中.(4)实现过程:A:初始,魔王语言接收后存放在demon[i]:初次遍历数组,将数组中括号内的元素入栈,同时插入相应首字母;C:再次遍历数组,将数组元素依次入队。(小写字母直接入队;大写字母经翻译成相应字符后入队;遇到括号,将栈中保存的元素依次出栈入队)在翻译过程中,如果依旧包含大写字母,则置flag为1,否则为0。D:将队列中元素赋值给demon[i]。如果此时flag=1,则再次重复C过程。直至所有元素为人类语言。E:输出demon[i]。此时数组中元素为对应的人类语言。注:如果程序中没有相应的对应关系,则翻译成“???”。二:概要设计:1:设定栈的抽象数据类型定义:ADTstack{数据对象:D={ai|ai∈CharSet,i=1,2,…,n,n>=0}数据关系:R1={<ai-1,ai>|ai-1,ai∈D,i=2,…,n}基本操作:initstack(&s)操作结果:(&s,e)初始条件::(&s,&e)初始条件::删除s的栈顶元素,并以e返回其值.}ADTstack2:设定队列的抽象数据类型:ADTqueue{数据对象:D={ai|ai∈Elemset,i=1,2,…,n,n>=0}数据关系:R1={<ai-1,ai>|ai-1,ai∈D,i=2,…,n}基本操作:initqueue(&q)操作结果:(&q,e)初始条件::(&q,&e)初始条件::删除q的队头元素,并用e返回其值.}ADTqueue3:本程序包含四个模块:1):statusmain(){初始化栈;初始化队列;接收魔王语言输入到数组demon[i];遍历数组将括号中元素进栈;while(数组demon[i]中元素有大写字母){翻译排序处理后入队列;将对列元素保存在数组demon[i];}输出人类语言(数组demon[i]);}2)(&temps)将括号内元素入栈,:(abcd)->)(&s,&q){遍历数组;{遇到小写字母,直接入队列;遇到大写字母,翻译大写后入队列;遇到括号,将栈中保存的元素依次出栈入队列;}}4)(&*q,key){switch(key){’???’}}各模块之间调用关系:主函数模块{括号内元素入栈处理模块;排序入队模块{翻译大写处理模块;}}三:#RUE1#defineFALSE0#defineOK1#defineERROR0#defineNULL0#defineOVERFLOW-2#defineMAXSIZE100#definestack_init_size100#definestackincrement10typedefcharselemtype;typedefcharqelemtype;typedefcharelemtype;typedefintstatus;chare;chardemon[MAXSIZE];{selemtype*base;selemtype*top;intstacksize
魔王语言解释 来自淘豆网m.daumloan.com转载请标明出处.