鱼C论坛

 找回密码
 立即注册
查看: 2269|回复: 3

括号匹配 我写的很麻烦 并且超时,哪位大佬帮忙看看,谢谢

[复制链接]
发表于 2017-9-29 21:35:09 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
#include <stdio.h>
#include <stdlib.h>
#include <ctype.h>
#include <math.h>


#define STACK_INIT_SIZE 20
#define STACKINCREMENT  10
#define MAXBUFFER       10
typedef char ElemType;
typedef struct
{
    ElemType *base;
    ElemType *top;
    int stacksize;
}SqStack;


void InitStack(SqStack &S)
{
    S.base=(ElemType*)malloc(STACK_INIT_SIZE*sizeof(ElemType));
    if (!S.base)exit(OVERFLOW);
    S.top=S.base;
    S.stacksize=STACK_INIT_SIZE;
    return;
}

void Push(SqStack &S,ElemType e)
{
   if(S.top-S.base>=S.stacksize)
   {
       S.base=(ElemType*)realloc(S.base,(S.stacksize+STACKINCREMENT)*sizeof (ElemType));
       if(!S.base)exit(OVERFLOW);
       S.top=S.base+S.stacksize;
       S.stacksize+=STACKINCREMENT;
   }
   *S.top++=e;
   return;
}

void Pop(SqStack &S,ElemType &e)
{
    if (S.top==S.base){return;};
    e=*--S.top;
}


int StackLen(SqStack S)
{
    return(S.top-S.base);
}


int main()
{
    SqStack S;
    char c,e;
    InitStack(S);
    scanf ("%c",c);//读入c
    while(c!='.')
    {
        switch(c)
        {
        case '(':
        case '[':
        case '{':
        Push(S,c);//如果是开始符,则入栈
        scanf("%c",c);//读入下一个符号
        if ('.'==c)
        {Pop(S,e);printf("NO\n",e);printf("%c-?",e);}//当开始符后面的符号直接是'.'的话,直接输出
        else break;//包含第一个字符是开始符的情况
        case '/':
        Push(S,c);
        scanf ("%c",c);
        Push(S,c);
        do
            {
                scanf ("%c",c);
            }while (c!='*'&&c!='.');
           if ('*'==c)
           {
               Push(S,c);
               scanf("%c",c);
               Push(S,c);
               scanf ("%c",c);
               break;
           }
            else {printf("NO\n");printf("/*-?");}
            break;
        case '*':
        printf ("NO\n");
        printf("?-*/");
        c='.';
        break;
        case ')':
        if (!StackLen(S)){printf("NO\n",c);printf ("?-%c");}
        else
        {
            Pop(S,e);
            if ('('!=e){printf("NO\n");printf("?-)");}
            else if('('==e)scanf("%c",c);
        }break;
         case ']':
        if (!StackLen(S)){printf("NO");printf("\n?-]");}
        else
        {
            Pop(S,e);
            if ('['!=e){printf("NO\n");printf("?-]");}
            else if('['==e)scanf ("%c",c);
        }break;
         case '}':
        if (!StackLen(S))printf("NO\n?-}");
        else
        {
            Pop(S,e);
            if ('{'!=e){printf("NO\n");printf("?-}");}
            else if('{'==e)scanf("%c",c);
        }break;
        }
    }
    if (!StackLen(S))printf ("\nYES");
    return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2017-9-29 22:37:22 | 显示全部楼层
我只想弱弱地问一句,为什么不直接用stack之类的?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2017-9-30 07:55:41 | 显示全部楼层
eglym 发表于 2017-9-29 22:37
我只想弱弱地问一句,为什么不直接用stack之类的?

不就是Stack吗
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-9-30 11:49:28 | 显示全部楼层

我的意思是直接用STL里面的Stack容器:
加个头文件<stack>
stack<char> s;
用下面的函数:
s.pop()
s.push()
而不用自己写的函数,STL里面的操作效率不知道怎么样,但是写程序会方便很多。
自己写stack函数主要是为了理解其中的大概过程。。我是这么认为的~~
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-9-30 19:32

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表