每日一道算法题(Leetcode 20)

What's past is prologue. 凡是过去,皆为序章。

题目

分析

  1. 我们可以用栈的结构来解决这道题。

  2. 我们使用while循环,每次读取字符串中一个元素进行操作,直到最后读取到 '\0'为止。

  3. 如果遇见 '(', '[' ,'{' 这三种左括号,则把该左括号入栈;如果遇见 ')', ']' ,'}' 这三种右括号,则出栈一个栈中的元素。

  4. 如果出栈的元素与右括号不匹配,则返回 false;如果匹配,则继续进行下一步。比如:这种情况 " ()[} "。

  5. 读取到右括号时,先判断栈中是否还有元素,如果没有元素出来匹配,则说明右括号存在不能匹配情况,则直接返回 false。比如:这种情况 '' ()) "。

  6. 对子字符串的遍历结束之后,需要再去判断栈中是否还有元素,如果有说明左括号存在不能匹配情况,则直接返回 false。比如:这种情况 '' (() "。

代码实现

cpp 复制代码
bool isValid(char* s) 
{
    typedef struct Stack 
    {
        char* arr;
        int capacity;
        int top;
    } Stack;
    void InitStack(Stack * ps) 
    {
        assert(ps);
        ps->arr = NULL;
        ps->capacity = ps->top = 0;
    }
    void PushStack(Stack* ps,char x)
    {
        assert(ps);
        if(ps->capacity == ps->top)
        {
            int newcapacity=ps->capacity==0?4:2*ps->capacity;
            char* tmp=(char*)realloc(ps->arr,sizeof(char)*newcapacity);
            if(tmp==NULL)
            {
                perror("realloc fail");
                exit(1);
            }
            ps->arr=tmp;
            ps->capacity=newcapacity;
        }      
        ps->arr[ps->top++]=x;
    }
    void PopStack(Stack * ps)
    {
        assert(ps);
        assert(ps->top!=0);
        ps->top--;
    }
    char TopStack(Stack * ps)
    {
        assert(ps);
        assert(ps->top!=0);
        return ps->arr[ps->top-1];
    }
    void DestroyStack(Stack * ps)
    {
        assert(ps);
	    if (ps->arr)
        {
		    free(ps->arr);//释放动态数组空间
        }
	    ps->arr = NULL;
	    ps->capacity = ps->top = 0;
    }
    Stack stack;
    InitStack(&stack);
    while(*s!='\0')
    {
        if(*s=='('||*s=='['||*s=='{')
        {
            PushStack(&stack,*s);
        }
        else
        {
            if(stack.top==0)
            {
                DestroyStack(&stack);
                return false;
            }
            char ch=TopStack(&stack);
            if((ch=='('&&*s==')')||(ch=='['&&*s==']')||(ch=='{'&&*s=='}'))
            {
                PopStack(&stack);
            }
            else
            {
                DestroyStack(&stack);
                return false;
            }
        }
        s++;
    }
    if(stack.top!=0)
    {
        DestroyStack(&stack);
        return false;
    }
    DestroyStack(&stack);
    return true;
}

致谢

感谢您花时间阅读这篇文章!如果您对本文有任何疑问、建议或是想要分享您的看法,请不要犹豫,在评论区留下您的宝贵意见。每一次互动都是我前进的动力,您的支持是我最大的鼓励。期待与您的交流,让我们共同成长,探索技术世界的无限可能!

相关推荐
C雨后彩虹14 小时前
ConcurrentHashMap 核心锁机制:CAS+Synchronized 的协同工作原理
java·数据结构·哈希算法·集合·hashmap
爱学大树锯14 小时前
1361 · 文字并排
算法
Tisfy14 小时前
LeetCode 2483.商店的最少代价:两次遍历 -> 一次遍历
算法·leetcode·题解·遍历
集芯微电科技有限公司14 小时前
DC-DC|40V/10A大电流高效率升压恒压控制器
c语言·数据结构·单片机·嵌入式硬件·fpga开发
C雨后彩虹14 小时前
HashMap的线程安全问题:原因分析与解决方案
java·数据结构·哈希算法·集合·hashmap
YGGP14 小时前
【Golang】LeetCode 279. 完全平方数
算法·leetcode
im_AMBER14 小时前
Leetcode 87 等价多米诺骨牌对的数量
数据结构·笔记·学习·算法·leetcode
月明长歌14 小时前
【码道初阶】Leetcode771 宝石与石头:Set 判成员 vs List 判成员(同题两种写法的差距)
java·数据结构·leetcode·list·哈希算法·散列表
import_random14 小时前
[算法]时间序列(介绍)
算法
wuk99814 小时前
MATLAB中求解和分析马蒂厄方程
人工智能·算法·matlab