数据l构W三章设计题?qing)参考答案[5]_跨考网
1.设计一个算法,判断一个算术表辑ּ中的括号是否配对。算术表辑ּ保存在带头结点的单@环链表中Q每个结Ҏ(gu)两个域:(x)ch?/span>linkQ其?/span>ch域ؓ(f)字符cd。?a target="_blank">南京邮电(sh)大学 2000五?/span>
【参考答案?/span>
[题目分析]表达式中的括h以下三对Q‘(’、‘)’、?/span>[’、?/span>]’、?/span>{’、?/span>}’,使用栈,当ؓ(f)左括h入栈Q右括号Ӟ若栈是其对应的左括P则退栈,若不是其对应的左括号Q则l论为括号不配对。当表达式结束,若栈为空Q则l论表达式括号配对,否则Q结辑ּ括号不配寏V?/span>
int Match(LinkedList la)
//术表达式存储在?/span>la为头l点的单循环链表中,本算法判断括h否正配?/span>
{char s[]; //s为字W栈Q容量够大
p=la->link; //p为工作指针,指向待处理结?/span>
StackInit(s); //初始化栈s
while (p!=la) //循环到头l点为止
{switch (p->ch)
{case ?/span>(?/span>:push(s,p->ch); break;
case ?/span>)?/span>:if(StackEmpty(s)||StackGetTop(s)!=?/span>(?/span>)
{printf(“括号不配对\n?/span>); return(0);} else pop(s);break;
case ?/span>[?/span>:push(s,p->ch); break;
case ?/span>]?/span>: if(StackEmpty(s)||StackGetTop(s)!=?/span>[?/span>)
{printf(“括号不配对\n?/span>); return(0);} else pop(s);break;
case ?/span>{?/span>:push(s,p->ch); break;
case ?/span>}?/span>: if(StackEmpty(s)||StackGetTop(s)!=?/span>{?/span>)
{printf(“括号不配对\n?/span>); return(0);} else pop(s);break;
} p=p->link; 后移指针
}//while
if (StackEmpty(s)) {printf(“括号配?/span>\n?/span>); return(1);}
else{printf(“括号不配对\n?/span>); return(0);}
}//法matchl束
[法讨论]法中对非括L(fng)字符未加讨论。遇到右括号Ӟ若栈I或栈顶元素不是其对应的左圆Q方、花Q括P则结论括号不配对Q退行。最后,若栈不空Q仍l论括号不配寏V?/span>
2022考研初复试已l接q尾壎ͼ考研学子全面q入2023届备?/b>Q跨考ؓ(f)23考研的考生准备?0大课包全E准备、全q复?fn)备考计划、目标院校专业辅对{全真复试模拟练?fn)和全程针对性指|2023考研的小伙伴针也已经开始择校和复习(fn)了,跨考考研畅学5.0版本全新升Q无Z在校在家都可以更自如的完成你的考研复习(fn)Q?/a>暑假集训?/span>带来了院校专业初步选择Q明方向;考研备考全q规划,核心知识点入门;个性化制定备考方案,助你赢在赯U,早出发一点离成功更q一点!
考研院校专业选择和考研复习(fn)计划 | |||
2023备考学?/td> | 2023U上U下随时学习(fn) | 34所自划UK校考研复试分数U汇?/td> | |
2022考研复试最全信息整?/a> | 全国各招生院校考研复试分数U汇?/a> | ||
2023全日制封闭训l?/span> | 全国各招生院校考研调剂信息汇?/a> | ||
2023考研先知 | 考研考试U目有哪些? | 如何正确看待考研分数U? | |
不同院校相同专业如何选择更适合自己?/a> | 从就业说考研如何择专业? | ||
手把手教你如何选专业? | 高校研究生教育各学科门类排行?/a> |
相关推荐
跨考考研评
班型 | 定向班型 | 开班时?/td> | 高定?/td> | 标准?/td> | 评介绍 | 咨询 |
U季集训 | 冲刺?/td> | 9.10-12.20 | 168000 | 24800?/td> | 班面授+专业??+专业译֮向辅?协议加强评(高定?+专属规划{疑(高定?+_化答?复试资源(高定?+复试译(高定?+复试指导(高定?+复试班主?v1服务(高定?+复试面授密训(高定?+复试1v1(高定? | |
2023集训畅学 | 非定向(政英?数政qQ?/td> | 每月20?/td> | 22800?协议? | 13800?/td> | 先行阶在U课E?基础阶在U课E?强化阶在U课E?真题阶在U课E?冲刺阶在U课E?专业NҎ(gu)一对一评+班主dE督学服?全程规划体系+全程试体系+全程_化答?择校择专业能力定位体p?全年关键环节指导体系+初试加强?初试专属服务+复试全科标准班服?/td> |