大家好,又见面了,我是你们的朋友全栈君。
括号匹配问题 假设一个算术表达式中包含圆括号、方括号和花括号三种类型的括号,编写一个函数,用来判别表达式中的括号是否正确配对,并设计一个测试主函数。
【算法思想】 在算术表达式中,右括号和左括号匹配的次序正好符合后到的括号要最先被匹配的“后进先出”堆栈操作特点,因此可以借助一个堆栈来进行判断。 括号匹配共有以下4种情况:
具体方法如下:顺序扫描算术表达式(表现为一个字符串),当遇到3种类型括号的左括号时,让该括号进栈。当扫描到某一种类型的右括号时,比较当前栈顶括号是否与之匹配,若匹配,则退栈继续进行判断:若当前栈顶括号与当前扫描的括号不相同,则左、右括号配对次序不正确;若字符串当前为某种类型右括号而堆栈已空,则右括号多于左括号:字符串循环扫描结束时,若堆枝非空(即堆枝中尚有某种类型左括号),则说明左括号多于右括号;如果未出现 上述3种情况,则说明左、右括号匹配正确。 我定义了新的头文件SeqList.h,再创建C源文件文件。
实际操作如下: ①创建SeqList.h头文件 ②创建结构体
③创建顺序表
主函数,如下:
此方法为我的学习记录,仅供参考。
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/129137.html原文链接:https://javaforall.cn
版权声明:
本文来源网络,所有图片文章版权属于原作者,如有侵权,联系删除。
本文网址:https://www.mushiming.com/mjsbk/13213.html