1113. 括号匹配

题目描述
给定一个只包含左右括号的合法括号序列,按右括号从左到右的顺序输出每一对配对的括号出现的位置(括号序列以0开始编号)。
输入
仅一行,表示一个合法的括号序列。
输出
设括号序列有n个右括号。则输出包括n行,每行两个整数l,r,表示配对的括号左括号出现在第l位,右括号出现在第r位。
样例输入
(())()
这题也真是醉了
一模一样的输出居然一个0一个100
正确
 1 #include<iostream>
 2 #include<cstdio>
 3 #include<cstring>
 4 using namespace std;
 5 char c[101];
 6 int js[100];
 7 void f()
 8 {
 9     int i=0,top=0,j=0;
10     while(i<strlen(c))
11     {
12         if(c[i]=='('){
13             js[j++]=i;
14         }
15         if(c[i]==')'){
16             cout<<js[--j]<<" "<<i<<endl;
17         }
18         i++;
19     }
20 }
21 int main()
22 {
23     cin>>c;
24     f();
25     return 0;
26 }
View Code

错误

 1 #include<iostream>
 2 #include<cstring>
 3 #include<cstdio>
 4 using namespace std;
 5 char a[10001];
 6 struct stack
 7 {
 8     int p;
 9     int num;
10 }s[1001];
11 int main()
12 {
13     gets(a);
14     int l=strlen(a);
15     int begin;
16     int now=0;
17     for(int i=0;i<l;i++)
18     {
19         if(a[i]=='(')
20         {
21             s[now].p=1;
22             s[now].num=i;
23             now++;
24         }
25         else
26         {
27             //s[now].p=2;
28             //s[now].num=i;
29             cout<<s[now-1].num<<" "<<i<<endl;
30             now--;
31         }
32     }
33     return 0;
34 }
View Code

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
括号匹配是指在一个字符串中,括号必须成对出现,左括号与右括号之间可能会有其他字符,但是左右括号的数量必须相等且匹配。例如,"((()))"、"()()"都是合法的括号匹配,而"((())"、")()("则不是。 基于栈的括号匹配算法的思路如下: 1. 遍历字符串中的每一个字符,如果是左括号('(', '[', '{'),则将其入栈;如果是右括号(')', ']', '}'),则需要判断栈顶元素是否与之匹配。 2. 如果栈顶元素与当前字符匹配,则将栈顶元素出栈,继续遍历下一个字符;否则括号匹配失败,返回false。 3. 如果字符串遍历结束后,栈为空,则括号匹配成功,返回true;否则括号匹配失败,返回false。 下面是使用 Python 实现基于栈的括号匹配算法的代码: ```python def is_valid_parentheses(s: str) -> bool: stack = [] mapping = {')': '(', ']': '[', '}': '{'} for c in s: if c in mapping: if not stack or stack[-1] != mapping[c]: return False stack.pop() else: stack.append(c) return not stack ``` 其中,mapping字典用于记录每个右括号与其对应的左括号。 测试用例可以包括以下几个场景: 1. 空字符串,返回True。 2. 只包含左括号或者右括号的字符串,返回False。 3. 字符串中括号不匹配的情况,返回False。 4. 字符串中括号匹配的情况,返回True。 例如: ```python assert is_valid_parentheses("") == True assert is_valid_parentheses("(") == False assert is_valid_parentheses(")") == False assert is_valid_parentheses("()") == True assert is_valid_parentheses("(()") == False assert is_valid_parentheses("()[]{}") == True assert is_valid_parentheses("([)]") == False assert is_valid_parentheses("{[]}") == True ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值