判断表达式中开闭括号是否配对出现。运用栈实现表达式开、闭括号是否配对出现算法

判断表达式中开闭括号是否配对出现。运用栈实现表达式开、闭括号是否配对出现算法

算法思想:

每次扫描到一个左括号就入栈,扫描到右括号就出一个栈顶元素,看括号类型是否匹配。

如果某次扫描到右括号发现栈中已无元素可出,则匹配失败(右括号多于左括号)

如果某次扫描到右括号,出栈顶元素,发现两个括号类型不一样,匹配失败

还有一种情况就是,你把右括号都扫描完了,结构栈中还有元素,匹配失败(左括号多于右括号)

c 复制代码
bool bracketCheck(char str[], int length) {
	//str是一个字符数组,里面存储了各种左括号和右括号
	//len表示该字符数组有多长
	SqStack S;
	InitStack(&S);//初始化一个栈
	for (int i = 0;i < length;i++) {
		if (str[i] == '(' || str[i] == '[' || str[i] == '{') {
			Push(&S, str[i]);//扫描到左括号,入栈
		}
		else {
			if (StackEmpty(&S))//扫描到右括号,但栈空
				return false;//匹配失败
			char topElem;
			Pop(&S, &topElem);//栈顶元素出栈
			//括号不匹配的三种情况
			if (str[i] == ')'&&topElem != '(')
				return false;
			if (str[i] == ']'&&topElem != '[')
				return false;
			if (str[i] == '}'&&topElem != '{')
				return false;
		}
	}
	return StackEmpty(&S);//全部匹配完,如果栈空则匹配成功
}



int main() {
	char str[6] = {'(',')','[',']','{','}'};
	int len=strlen(str);
	if (bracketCheck(str,6)) {
		printf("匹配成功");
	}
	else {
		printf("匹配失败");
	}
	return 0;
}
相关推荐
玛卡巴卡ldf12 小时前
【LeetCode 手撕算法】(二分查找)搜索插入位置、搜索二维矩阵、查找数组相同的所有位置、搜索旋转排序数组、旋转升序数组的最小值
数据结构·算法·leetcode
谷雨不太卷20 小时前
进程的状态码
java·前端·算法
散峰而望20 小时前
【算法竞赛】C/C++ 的输入输出你真的玩会了吗?
c语言·开发语言·数据结构·c++·算法·github
躺不平的理查德20 小时前
时间复杂度与空间复杂度备忘录
数据结构·算法
yaki_ya20 小时前
yaki-C语言:从概念基础到内存解析---数组(array)完全指南
java·c语言·算法
刃神太酷啦20 小时前
扒透 STL 底层!map/set 如何封装红黑树?迭代器逻辑 + 键值限制全手撕----《Hello C++ Wrold!》(23)--(C/C++)
java·c语言·javascript·数据结构·c++·算法·leetcode
挽星安21 小时前
代码随想录算法训练营第五十天|卡码网 99 岛屿数量、卡码网 100 最大岛屿的面积
算法
葫三生21 小时前
《论三生原理》系列构建文理同构的认知体系?
人工智能·科技·深度学习·算法·机器学习·transformer
多加点辣也没关系21 小时前
数据结构与算法|第六章:队列
数据结构·算法·队列
_深海凉_1 天前
LeetCode热题100-分割回文串
算法·leetcode·职场和发展