首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
阅读以下说明和C函数,填补C函数中的空缺(1)~(5),将解答写在对应栏内。 [说明] 假设一个算术表达式中可以包含以下三种括号:“(”和“)”、“[”和“]”及“{”和“}”,并且这三种括号可以按照任意的次序嵌套使用。 下面仪考虑表达式
阅读以下说明和C函数,填补C函数中的空缺(1)~(5),将解答写在对应栏内。 [说明] 假设一个算术表达式中可以包含以下三种括号:“(”和“)”、“[”和“]”及“{”和“}”,并且这三种括号可以按照任意的次序嵌套使用。 下面仪考虑表达式
admin
2012-01-13
70
问题
阅读以下说明和C函数,填补C函数中的空缺(1)~(5),将解答写在对应栏内。
[说明]
假设一个算术表达式中可以包含以下三种括号:“(”和“)”、“[”和“]”及“{”和“}”,并且这三种括号可以按照任意的次序嵌套使用。
下面仪考虑表达式中括号的匹配关系,其他问题暂时忽略。例如,表达式[a-(b-5)*c[{}]中的括号是完全匹配的,而表达式[a-(b-5]))*c中的括号不是完全匹配的,因为“(”与“]”不能匹配,而且多了一个“)”,即缺少一个与“)”相匹配的“(”。
函数if Matched(char expr[])的功能是用栈来判断表达式中的括号是否匹配,表达式以字符串的形式存储在字符数组expr中。若表达式中的括号完全匹配,则该函数的返回值为Matched,否则返回值为Mismatched。
该函数的处理思路如下:
(1)设置一个初始为空的栈,从左至右扫描表达式。
(2)若遇上左括号,则令其入栈;若遇上右括号,则需要与栈顶的左括号进行匹配。
(3)若所遇到的右括号能与栈顶的左括号配对,则令栈顶的左括号出栈,然后继续匹配过程;否则返回Mismatched,结束判断过程。
(4)若表达式扫描结束,同时栈变为空,则说明表达式中的括号能完全匹配,返回Matched。
函数if Matched中用到了两种用户白定义数据类型BOOL和STACK,其中,BOOL类型的定义如下:
typedef enum {Mismatched, Matched} BOOL;
STACK(即栈类型)的定义省略,栈的基本操作的函数原型说明如下:
void InitStack(STACK*S):初始化一个空栈。
void Push(STACK*S. char e):将一个字符压栈,栈中元素数目增1。
void Pop(STACK*S):栈顶元素出栈,栈中元素数目减1。
char Top(STACK S):返回非空栈S的栈顶元素值,栈中元素数目不变。
int IsEmpty(STACK S):若S是空栈,则返回1,否则返回0。
[C函数]
BOOL ifMatched(char expr[])
{
char *cptr; /*cptr指向表达式中的字符*/
STACK S;
char e;
InitStack(&S); /*构造一个空栈*/
for(cptr=expr; *cptr!=’\0’ (1) ){
if(*cptr==’(’ || *cptr==’[’ || *cptr==’(’)
(2) ;
else
if(*cptr==’)’ || *cptr==’]’ || *cptr==’)’){
if(IsEmpty(S))
return Mismatched;
e= (3) ;/*取栈顶的左括号*/
if (*cptr==’)’ && e!=’(’ ) return Mismatched;
if(*cptr==’]’ &&e!=’[’) return Mismatched;
if (*cptr==’)’ &&e!=’{’ ) return Mismatched;
(4) ;/*栈顶的左括号出栈*/
}
}
if( (5) )return Matched;
return Mismatched;
}
选项
答案
cptr++ 或 ++cptr 或 cptr+=1 或 cptr=cptr+1 Push(&S,*cptr) Top(S) Pop(&S) IsEmpty(S)
解析
本题考查C程序设计基本能力。
由于已经将表达式以字符串的形式存入字符数组expr,因此指针cptr就用于指示表达式中的每个字符。显然,以下for语句用于扫描expr中的每个字符:
for(cptr=expr; *cptr!=’\0’; (1) )
因此,空(1)处应填入cptr++或其等价形式。
空(2)处进行处理的前提是遇到了左括号,因此,根据题目中对函数if Matched的处理思路描述,这时应进行压栈操作,即应填入Push(&S,*cptr),这里要注意函数调用时实参的形式。
由于弹栈操作不能返回栈顶元素,因此根据注释,空(3)处需要读取栈项元素,即应填入Top(S),空(4)处填入Pop(&S)。
由于表达式扫描结束且同时栈变为空,才说明表达式中的括号能完全匹配,因此,for语句的条件表达式*cptr!=’\0’不成立时表达式结束,此时控制流可以到达空(5)所在语句,在此需要判断栈的状态来决定括号是否完全匹配,即空(5)处应填入IsEmpty(S)。
转载请注明原文地址:https://kaotiyun.com/show/86jZ777K
本试题收录于:
程序员下午应用技术考试题库软考初级分类
0
程序员下午应用技术考试
软考初级
相关试题推荐
在Excel2010中,设A1单元格中的值为20,A2单元格中的值为60,若在C1单元格中输入函数“=AVERAGE(A1,A2)”,按回车键后,,则C1单元格中的值为(
某村领导要求信息处理技术员估计该村一池塘中的鱼的大致数量。该技术员想出了一个办法:先从池塘中捕出30条鱼,在每条鱼身上做一记号后,又放回池塘。几天后,再从该池塘中捕出40条鱼,发现其中有2条是有记号的。因此,他估计该池塘鱼的数量大致为(68)条(假设这几天
在Excel2007中,若在单元格A1中输入函数“=MID(“RUANKAO”,1,4)”,按回车键后,则A1单元格中的值为()。
在大型分布式信息系统中,为提高信息处理效率,减少网络拥堵,信息存储的原则是:数据应尽量(66)________________。
在Access中,(65)不属于数据表的复制方式。
小张为本企业录入一篇领导讲话文稿。文稿中引用了该企业2008年的销售额和各产品的利润等数据。小张考虑到目前是2010年,从信息的实效性出发,决定对文稿中的这部分内容进行处理,则______做法最为恰当。
计算机在接通电源后,系统首先由(41)程序对内部每个设备进行测试。
阅读以下说明,回答问题1至问题6,将解答填入答题纸对应的解答栏内。【说明】在Linux下安装配置DHCP服务,DHCP服务程序/usr/sbin/dhcpd需要读取配置文件/etc/d/hcpd.conf,以下是一个DHCP配置文件的主要内容:
连接主机A与交换机的单根网线的最大长度为多少?该局域网中的集线器每个端口平均享有的带宽是多少?
Web客户端与服务器共同遵守(1)协议,默认端口号是(2),协作的过程是:Web客户端在浏览器的地址栏输入(3),连接到相应的WWW服务器上并获得指定的Web文档,然后断开与WWW服务器的连接,最后,Web文档以(4)格式在客户端解释。“配置基于IP的
随机试题
应根据油井结蜡特点、程度、含水等试验来确定()周期、热洗排量、热洗液温度、洗井时间、洗井方式。
癫狂证的病因病机主要有()(2005年第138题)
出现持续压榨性或窒息性胸部闷痛.最可能的诊断是
西咪替丁的作用是()。
杆OA与均质圆轮的质心用光滑铰链A连接,如图所示,杆OA质量为M,长为L,转动的角速度为ω,圆轮质量为m,半径为r,圆轮绕A点的角速度为ω1,则系统动能为()。
某学校的计算机的配置为“IntelPentiumE5400s2.7G/2048M/1000(3/DVD±Rw/20””,其中通常用来表示内存大小的是_____。
公安机关各警种间的分工与协作是各警种正确履行职责所不可或缺的条件。但是警种的设置并不是兰成不变的,它必须随着形势的发展、公安工作的需要,作相应的调整;增设新警种,淘汰不适应形势的警种。()
我国下列省级行政区中,受寒潮影响较小的是()。
A、Yesterday.B、Twodaysago.C、Threedaysago.D、Earlylastweek.B时间计算题。关键听清第二句女士的回答,“thedaybeforeyesterday”是指前天,所以当问到上次见到是什
Inthemidstofaperiodofrapidlanguageextinction,withalanguageestimatedtodieeverytwoweeks,linguistshavefounda
最新回复
(
0
)