括号匹配为题(栈的思想)哈

数据结构实验之栈四:括号匹配

Time Limit: 1000ms   Memory limit: 65536K  有疑问?点这里^_^

题目描述

给你一串字符,不超过50个字符,可能包括括号、数字、字母、标点符号、空格,你的任务是检查这一串字符中的( ) ,[ ],{ }是否匹配。

输入

输入数据有多组,处理到文件结束。

输出

如果匹配就输出“yes”,不匹配输出“no”

示例输入

sin(20+10)
{[}]

示例输出

yes
no

提示

我的分析:运用栈的思想,读到左边的括号,就把它推进栈里面去,如果遇到的是右边的括号,就让当前读到的括号和栈顶的元素括号进行匹配。

如果匹配的上,就将栈的数字指针往后移一位(理论上应该将栈顶元素出栈,介于我的技术,我利用的是指针移位)。如果没有匹配上,

直接跳出循环,printf("no\n");

#include <stdio.h>
#include <string.h>

char s[100], e=0;

void main()
{
    int i, f;
    int len;
    char a[100];
    while(gets(a)!=NULL)
    {
        f = 1;
        e = 0;
        len = strlen(a);
        for(i=0; i<len; i++)
        {
            if(a[i]==‘{‘ || a[i]==‘[‘ || a[i]==‘(‘)
            {
                s[e++] = a[i];
            }
            if(a[i]==‘)‘)
            {
                if(e==0)
                {
                    f=0;
                    break;
                }
                if(e>0 && s[e-1]==‘(‘)
                {
                    e = e-1;
                }
                else if(e>0 && s[e-1]!=‘(‘)
                {
                    f=0;
                    break;
                }
            }
            if(a[i]==‘]‘)
            {
                if(e==0)
                {
                    f=0;
                    break;
                }
                if(e>0 && s[e-1]==‘[‘)
                {
                    e = e-1;
                }
                else if(e>0 && s[e-1]!=‘[‘)
                {
                    f=0;
                    break;
                }
            }
            if(a[i]==‘}‘)
            {
                if(e==0)
                {
                    f=0;
                    break;
                }
                if(e>0 && s[e-1]==‘{‘)
                {
                    e = e-1;
                }
                else if(e>0 && s[e-1]!=‘{‘)
                {
                    f=0;
                    break;
                }
            }
        }
        if(f==0 || e>0)
            printf("no\n");
        else if(e==0)
            printf("yes\n");
    }
}

括号匹配为题(栈的思想)哈,布布扣,bubuko.com

时间: 2024-10-08 10:17:26

括号匹配为题(栈的思想)哈的相关文章

算法学习 - 括号匹配(栈实现)C++

括号匹配是栈最典型的应用了. 其实思路很简单,就是遇到一个左括号就压栈,遇到一个右括号就弹栈,看是否匹配就好了.最后检查下栈里是不是有剩余的括号就行了. 上代码~: // // main.cpp // bracketMatch // // Created by Alps on 14-7-28. // Copyright (c) 2014年 chen. All rights reserved. // #include <iostream> #define ElementType char usi

括号匹配的栈实现

括号匹配的栈实现 问题:判断一个文本中,括号是否匹配? 思路:从头到尾扫描字符串,每次遇到左括号(如'(', '[', '{')就压入堆栈,如果遇到右括号(如')', ']', '}')就与栈顶元素比较,如果成对,OK,否则判断不匹配. 代码如下: #include <iostream> #include <stack> #include <set> #include <string> using namespace std; /* * vaild retu

括号匹配(链栈实现)

/* 建立链栈实现括号匹配问题 创建栈,判断是否空栈 */ #include<stdio.h> #include<stdlib.h> #include<string.h> #define status int typedef struct node { char ch; node* next; }SNode; typedef struct { SNode *top; //SNode *base; }Stack; //创建空栈 base 赋值为NULL, top 指向栈顶

顺序栈(进制转换 + 括号匹配 + 判断栈表 + 最长括号匹配长度)

#include <stdio.h> #include <stdlib.h> #include <iostream> using namespace std; #define TRUE 1 #define FALSE 0 #define OK 1 #define ERROR 0 #define INFEASIBLE -1 #define OVERFLOW -2 #define STACK_INIT_SIZE 100 #define STACKLINCREMENT 10

OJ1147括号匹配加强版(栈)

惨兮兮的被刷掉2%的通过率后在经过思考和dalao的指点后终于A掉了这道题 强烈建议修改这题的样例,实在太迷惑人,各种错误算法都能过 比如说这是一份错误代码,看懂了也不要学思路,和正解不知道差到哪里去了: 惨兮兮,WA掉代码: #include <iostream> #include <iomanip> #include <cmath> #include <cstdio> #include <cstring> #include <algor

题目1153:括号匹配问题(栈的使用)

题目链接:http://ac.jobdu.com/problem.php?pid=1153 详解链接:https://github.com/zpfbuaa/JobduInCPlusPlus // // 1153 括号匹配问题.cpp // Jobdu // // Created by PengFei_Zheng on 08/04/2017. // Copyright © 2017 PengFei_Zheng. All rights reserved. // #include <stdio.h>

表达式括号匹配(栈)

1386: 表达式括号匹配 时间限制: 1 Sec  内存限制: 128 MB提交: 12  解决: 9[提交][状态][讨论版] 题目描述 假设一个表达式有英文字母(小写).运算符(+,-,*,/)和左右小(圆)括号构成,以"@"作为表达式的结束符.请编写一个程序检查表达式中的左右圆括号是否匹配,若匹配,则返回"YES":否则返回"NO".表达式长度小于255,左圆括号少于20个. 输入 包括一行数据,即表达式 输出 包括一行,即"Y

括号匹配(栈)

检查一段C语言代码的小括号( ). 中括号 [ ] 和大括号{ } 是否匹配. 输入格式: 在一行中输入一段C语言代码,长度不超过1000个字符(行末以换行符结束). 输出格式: 第一行输出左括号的数量和右括号的数量,中间以一个空格间隔.若括号是匹配的,在第二行打印YES,否则打印NO. 输入样例1: for(int i=0; i<v; i++){ visited[i] = 0; for(int j=0; j<v; j++) scanf("%d",&(g->A

括号匹配--java栈实现

假设括号都是(),{},[],{[]()},{()()}这种可以匹配的,存在{(}),([)均为错. 1 public boolean match(String str) { 2 //String str="[()()]{}"; 3 Stack <Character> s = new Stack<Character>(); 4 for (int index=0; index<str.length();index++) { 5 switch(str.char