一类括号匹配问题
题目
在程序设计中,常常使用小括号强调表达式的运算顺序,但是,左右小括号必须匹配。现给定一个不多于500个符号的表达式(串),其中可能存在多个小括号,想检查小括号的匹配问题。如果存在小括号不匹配,则输出 mismatch;如果所有小括号匹配,则按左右括号的匹配距离由小到大输出左、右括号的位置;若多个匹配的距离相等,则左括号先出现的匹配先输出;如果整个串中没有小括号,则左右位置均输出0,即 0,0; ,规定,串中第一个符号的位置为1。
匹配距离=右括号位置 - 左括号位置。
输入
一串符号
输出
按匹配距离的增序输出匹配对的左右位置,逗号间隔;如果距离相同,则按左括号出现的先后顺序输出;如果整个序列中出现不匹配现象,则输出 mismatch;
样例输入
(x+y*(z-5)(x+y))(x+98)
样例输出
6,10
12,16
19,24
1,17
思路:
虽然有嵌套括号的情况,但是右括号一定和最近的左括号相匹配(从左往右遍历);同理,如果从右向左遍历,左括号一定与最近的右括号相匹配。本题把排序完全交给cmp,因此只需要找到匹配的括号即可。
#include <iostream>
#include <algorithm>
using namespace std;
struct records
{
int pleft;
int pright;
int distance;
}brackets[500];
int main()
{
char lines[1000]; //输入数据
cin >> lines;
int len = strlen(lines