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

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
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值