博客
关于我
括号匹配问题
阅读量:229 次
发布时间:2019-03-01

本文共 2377 字,大约阅读时间需要 7 分钟。

typedef char DataType;typedef struct Stack {       DataType* arr;    int size;    int capacity;}Stack;//初始化void StackInit(Stack* st, int n) {       //创建一个n个元素的栈    st->size = 0;    st->capacity = n;    st->arr = (DataType*)malloc(sizeof(DataType) * n);}//进栈void StackPush(Stack* st, DataType data) {       //插入时先检查栈是否已满    if (st->size >= st->capacity) {           //扩容        st->capacity += st->capacity;        st->arr = (DataType*)realloc(st->arr, st->capacity * sizeof(DataType));    }    //尾插    st->arr[st->size] = data;    st->size++;}//出栈void StackPop(Stack* st) {       if (st->size == 0) {           //空栈, 删除失败        return;    }    //尾删    st->size--;}//得到栈顶元素DataType getStackTop(Stack* st) {       return st->arr[st->size - 1];}//得到栈的大小int getStackSize(Stack* st) {       return st->size;}//判空int StackEmpty(Stack* st) {       if (st->size == 0) {           return 1;    }    return 0;}//销毁void StackDestory(Stack* st) {       free(st->arr);    st->arr = NULL;    st->capacity = 0;    st->size = 0;}bool isValid(char * s){       Stack st;    StackInit(&st, 10);    //创建一个括号的映射    char map[3][2] = {   {   '(', ')'}, {   '[', ']'}, {   '{', '}'}};    //遍历字符串    while (*s != '\0') {           //先找到左括号, 放入栈中, 直到出现第一个右括号        //flag  1表示找到了一个左括号  0代表没找到        int falg = 0;        for (int i = 0; i < 3; i++) {               //循环找左括号            if (*s == map[i][0]) {                   falg = 1;                StackPush(&st, *s);                s++;                break;            }        }        //下面这个循环只有当第一个右括号出现的时候才会进入        if (falg == 0) {               //检查栈是否为空            if (StackEmpty(&st) == 1) {                   //栈为空说明没有找到左括号, 直接返回false                return false;            }            //栈不为空, 开始检查括号是否匹配            for (int j = 0; j < 3; j++) {                   //循环找右括号                if (*s == map[j][1]) {                       //找到右括号后, 取出栈顶元素, 检查是否匹配                    //匹配则继续, 不匹配直接返回 false                    char top = getStackTop(&st);                    if (top == map[j][0]) {                           //括号匹配, 出栈并更新s                        StackPop(&st);                        s++;                        break;                    }                    else                         return false;                }            }        }    }    if (StackEmpty(&st) == 1)        return true;    else         return false;}

转载地址:http://uunv.baihongyu.com/

你可能感兴趣的文章
Nacos 单机集群搭建及常用生产环境配置 | Spring Cloud 3
查看>>
Nacos 启动报错[db-load-error]load jdbc.properties error
查看>>
Nacos 报Statement cancelled due to timeout or client request
查看>>
Nacos 注册服务源码分析
查看>>
Nacos 融合 Spring Cloud,成为注册配置中心
查看>>
Nacos-注册中心
查看>>
Nacos2.X 源码分析:为订阅方推送、服务健康检查、集群数据同步、grpc客户端服务端初始化
查看>>
Nacos2.X 配置中心源码分析:客户端如何拉取配置、服务端配置发布客户端监听机制
查看>>
Nacos2.X源码分析:服务注册、服务发现流程
查看>>
NacosClient客户端搭建,微服务注册进nacos
查看>>
Nacos中使用ribbon
查看>>
Nacos使用OpenFeign
查看>>
Nacos使用Ribbon
查看>>
Nacos做注册中心使用
查看>>
Nacos做配置中心使用
查看>>
Nacos入门过程的坑--获取不到配置的值
查看>>
Nacos原理
查看>>
Nacos发布0.5.0版本,轻松玩转动态 DNS 服务
查看>>
Nacos启动异常
查看>>
Nacos命名空间配置_每个人用各自自己的命名空间---SpringCloud Alibaba_若依微服务框架改造---工作笔记001
查看>>