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

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

算法思想:

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

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

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

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

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;
}
相关推荐
滴滴答滴答答20 小时前
LeetCode Hot100 之 17 有效的括号
算法·leetcode·职场和发展
掘根20 小时前
【C++STL】二叉搜索树(BST)
数据结构·c++·算法
老鼠只爱大米20 小时前
LeetCode经典算法面试题 #20:有效的括号(数组模拟法、递归消除法等五种实现方案详细解析)
算法·leetcode··括号匹配·数组模拟法·递归消除法
yxc_inspire20 小时前
2026年寒假牛客训练赛补题(五)
算法
不想看见40420 小时前
6.3Permutations -- 回溯法--力扣101算法题解笔记
笔记·算法·leetcode
诗词在线21 小时前
孟浩然诗作数字化深度实战:诗词在线的意象挖掘、检索优化与多场景部署
大数据·人工智能·算法
芜湖xin21 小时前
【题解-Acwing】113. 特殊排序
算法·插入排序·二分
代码栈上的思考1 天前
双指针法:从三道经典题看双指针的核心思想
数据结构·算法
J-TS1 天前
线性自抗扰控制LADRC
c语言·人工智能·stm32·单片机·算法
Ivanqhz1 天前
半格与数据流分析的五个要素(D、V、F、I、Λ)
开发语言·c++·后端·算法·rust