顺序栈的实现&括号匹配问题

typedef char elemtype;
typedef struct {
    elemtype *a;
    int top;
    int capacity;

} Mystack;


bool mystackEmpty(Mystack* obj) {
    if(obj->top==0)
    {
        return true;
    }
    return false;

}
void mystackCreate(Mystack* s) {
    s->a=NULL;
    s->top=0;
    s->capacity=0;
}

void mystackPush(Mystack* obj, int x) {

   if(obj->top==obj->capacity)
   {
       int newcapacity=obj->capacity==0?4:obj->capacity*2;
       elemtype* tmp=(elemtype*)realloc(obj->a,newcapacity*sizeof(elemtype));
       if(tmp==NULL)
       {
           perror("realloc fail");
           return;
       }
       obj->a=tmp;
       obj->capacity=newcapacity;

   }
    obj->a[obj->top]=x;
    obj->top++;
}

int mystackPop(Mystack* obj) {
    assert(!mystackEmpty(obj));
    obj->top--;
    return obj->a[obj->top];

}

elemtype mystacktop(Mystack* obj) {
    assert(!mystackEmpty(obj));
        return obj->a[obj->top-1];
    
    
}


void mystackFree(Mystack* obj) {
    free(obj->a);
    obj->top=0;
    obj->capacity=0;
}

bool isValid(char * s){
    Mystack S;
    mystackCreate(&S);
    char top;
    
    while(*s)
    {
        if(*s=='('||*s=='{'||*s=='[')
        {
            mystackPush(&S,*s);
        }
        else
        {
            if(mystackEmpty(&S))
            {
                mystackFree(&S);
                return false;
            }
            top=mystacktop(&S);
            mystackPop(&S);
        if((*s==')'&&top!='(')||(*s=='}'&&top!='{')||(*s==']'&&top!='['))
        {
            return false;
        }
    }
        ++s;
    }
     bool ret=mystackEmpty(&S);
     mystackFree(&S);
     return ret;
}

注意:当栈为空的时候(包括匹配判断的中途栈为空的情况)返回之前要释放内存,否则会导致内存泄漏 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用顺序栈实现括号匹配的步骤如下: ```C++ // 定义栈结构体 typedef struct { char data[MAXSIZE]; int top; } SqStack; // 初始化栈 void InitStack(SqStack &S) { S.top = -1; } // 判断栈是否为空 bool StackEmpty(SqStack S) { if (S.top == -1) { return true; } return false; } // 进栈 bool Push(SqStack &S, char x) { if (S.top == MAXSIZE - 1) { return false; } S.top++; S.data[S.top] = x; return true; } // 出栈 bool Pop(SqStack &S, char &x) { if (S.top == -1) { return false; } x = S.data[S.top]; S.top--; return true; } // 获取栈顶元素 bool GetTop(SqStack S, char &x) { if (S.top == -1) { return false; } x = S.data[S.top]; return true; } // 判断括号是否匹配 bool BracketMatch(char exp[]) { SqStack S; InitStack(S); int i = 0; char e; while (exp[i] != '\0') { switch (exp[i]) { case '(': case '[': case '{': Push(S, exp[i]); break; case ')': if (StackEmpty(S)) { return false; } Pop(S, e); if (e != '(') { return false; } break; case ']': if (StackEmpty(S)) { return false; } Pop(S, e); if (e != '[') { return false; } break; case '}': if (StackEmpty(S)) { return false; } Pop(S, e); if (e != '{') { return false; } break; default: break; } i++; } if (StackEmpty(S)) { return true; } return false; } ``` 以上代码实现顺序栈的初始化、进栈、出栈、获取栈顶元素等基本操作,以及括号匹配的判断。在判断括号匹配时,遇到左括号则入栈,遇到右括号则弹出栈顶元素检查是否匹配。如果匹配则继续扫描,否则返回false。最后判断栈是否为空,如果为空则说明括号匹配成功,返回true,否则返回false。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值