当前位置: 首页 > news >正文

括弧匹配检验(信息学奥赛一本通-1354)

【题目描述】

假设表达式中允许包含两种括号:圆括号和方括号,其嵌套的顺序随意,如([ ]())或[([ ][ ])]等为正确的匹配,[( ])或([ ]( )或 ( ( ) ) )均为错误的匹配。

现在的问题是,要求检验一个给定表达式中的括弧是否正确匹配?

输入一个只包含圆括号和方括号的字符串,判断字符串中的括号是否匹配,匹配就输出 “OK” ,不匹配就输出“Wrong”。输入一个字符串:[([][])],输出:OK。

【输入】

输入仅一行字符(字符个数小于255)。

【输出】

匹配就输出 “OK” ,不匹配就输出“Wrong”。

【输入样例】

[(])

【输出样例】

Wrong

【题解代码】

#include<bits/stdc++.h>
using namespace std;

int main()
{
	stack<char> stk;
	char c;
	while (cin >> c)
	{
		if (c == '(' || c == '[')stk.push(c);
		else if (c == ')' || c == ']')
		{
			if (stk.empty())
			{
				cout << "Wrong";
				return 0;
			}
			else if (c == ')' && stk.top() == '(') stk.pop();
			else if (c == ']' && stk.top() == '[') stk.pop();
			else
			{
				cout << "Wrong";
				return 0;
			}
		}
	}
	if (stk.empty()) cout << "OK";
	else cout << "Wrong";

	return 0;
}

相关文章:

  • Cherry Studio搭建本地知识库,结合DeepSeek实现RAG
  • AM32-MultiRotor-ESC项目固件编译和烧录方法介绍
  • 【Spring】Spring框架介绍
  • C/C++蓝桥杯算法真题打卡(Day7)
  • 生物化学笔记:医学免疫学原理03 超抗原+丝裂原+疫苗佐剂
  • BLE 4.0开发技术全景解析
  • [自动化] 【八爪鱼】使用八爪鱼实现CSDN文章自动阅读脚本
  • (自用)在派上设置自启动时的问题
  • 0323-哈夫曼数、哈夫曼编码
  • proteus仿真stm32f103c8程序运行不起来的问题分析与解决
  • Jboss漏洞再现
  • C51知识点
  • 代码随想录算法训练营第十五天|右旋字符串
  • Linux的文件上传下载的lrzsz库的安装与使用
  • 《当人工智能遇上广域网:跨越地理距离的通信变革》
  • 08_双向循环神经网络
  • React 中useMemo和useCallback Hook 的作用,在什么场景下使用它们?
  • 图书管理系统系统-Java、SpringBoot、Vue和MySQL开发的图书馆管理系统
  • 文心快码 使用体验与介绍
  • 分布式算法:Paxos Raft 两种共识算法
  • 亮剑浦江丨上海网信部门处罚一批医疗服务类互联网企业,三大类问题值得关注
  • 深一度|“凑合过”的利物浦,英超第二冠只求性价比
  • “富卫保险冠军赛马日”创双纪录,打造赛马旅游盛宴,印证香港联通国际优势
  • 福建省莆田市原副市长胡国防接受审查调查
  • 南方医科大学原副校长宁习洲主动投案,接受审查调查
  • 恒瑞医药一季度营收72亿元,净利增超36%:授权交易推动利润增长