【栈与队列面试题】有效的括号(动图演示)

简介: 【栈与队列面试题】有效的括号(动图演示)

leetcode20.括号匹配问题


前言:

💥🎈个人主页:Dream_Chaser~ 🎈💥

✨✨刷题专栏:http://t.csdn.cn/UlvTc

⛳⛳本篇内容:力扣上栈与队列的面试OJ题目


1.问题描述

给定一个只包括 '('')''{''}''['']' 的字符串 s ,判断字符串是否有效。

有效字符串需满足:

  1. 左括号必须用相同类型的右括号闭合。
  2. 左括号必须以正确的顺序闭合。
  3. 每个右括号都有一个对应的相同类型的左括号。

48cb74344ee4479bb98574240437d5ea.png

2.前提准备

栈的实现

#pragma once
#include<stdlib.h>
#include<assert.h>
#include<stdbool.h>
#include<stdio.h>
typedef int STDataType;
typedef struct Stack
{
  STDataType* a;
  int top;//栈顶的位置
  int capacity;//栈的容量
}ST;
void STInit(ST* pst);
void STDestroy(ST* pst);
void STPush(ST* pst,STDataType x);
void STPop(ST* pst);
STDataType STTop(ST* pst);
bool  STEmpty(ST* pst);
int STSize(ST*pst);
void STInit(ST* pst)
{
  assert(pst);
  pst->a = NULL;//栈底
  //top不是下标
  pst->top = 0;//指向栈顶元素的下一个位置
  pst->capacity = 0;
}
void STDestroy(ST* pst)
{
  assert(pst);
  free(pst->a);
  pst->a = NULL;
}
void STPush(ST* pst,STDataType x)
{
  if (pst->top == pst->capacity)
  {
    int newCapacity = pst->capacity == 0 ? 4 : pst->capacity * 2;
    STDataType* tmp = (STDataType*)realloc(pst->a, newCapacity * sizeof(STDataType));
    if (tmp == NULL)
    {
      perror("realloc fail");
      return;
    }
    pst->a = tmp;//返回的是realloc出来的内存块的地址
    pst->capacity = newCapacity;//把扩容后的空间大小赋值给栈容量
  }
  pst->a[pst->top] = x;//先放值
  pst->top++;//再++
}
void STPop(ST* pst)
{
  assert(pst);
  assert(!STEmpty(pst));
  pst->top--;
}
STDataType STTop(ST* pst)
{
  assert(pst);
  assert(!STEmpty(pst));
  return pst->a[pst->top - 1];
}
bool STEmpty(ST* pst)//栈为空返回true,不为空返回false
{
  //assert(pst);
  //if (pst->top == 0)
  //{
  //  return true;
  //}
  //else
  //{
  //  return false;
  //}
  return pst->top == 0;
}
int STSize(ST* pst)
{
  assert(pst);
  return pst->top;
}


3.问题题解        

s指向的是右括号,top存储的是左括号st(栈顶指针)a(栈底指针)

  1. 只要有一次不对应的情况,那么程序直接返回false
  2. 字符串遍历结束,若栈不为空,直接返回false
  3. 在比较过程中,若遇到栈为空,可是此时字符串未遍历完,直接返回false

第一种情况:左括号多余

image.gif

第二种情况:括号没有多余,但是类型匹配不上

54d3b9b74f404991b9e2e868f36bcd0e.gif

第三种情况:右括号多余

70f5868b74e446bf83afdbc13eb5cd3d.gif

4b1d316a513a4904a127f0d038c57bdc.png

代码实现:

bool isValid(char * s){
    ST st;
    STInit(&st);
    while(*s)//*s就是输入的那个x的值
    {
    //1.左括号入栈
    if(*s == '(' || *s == '['  || *s == '{')
    {
        STPush(&st, *s);    
    }
    else
    {
        if(STEmpty(&st))//栈为空也需要销毁,因为它malloc了空间,空间在那占用着,只是数据没填进去
        {
            STDestroy(&st);
            return false;
        }
        //右括号出栈匹配
        char top=STTop(&st);
        STPop(&st);
         //只要有一个不匹配,直接返回false
        //左括号和右括号相等说明不了问题,只能说明这一次,这一对括号匹配,还有其它括号不匹配的
        //所以要找到不继续的条件
        if((*s == ']' && top!= '[')
        ||(*s == ')'&& top !='(')
        ||(*s=='}' && top!='{'))
        {
            STDestroy(&st);
            return false;
        }
        }
      ++s;//字符指针的移动
    }
    bool ret=STEmpty(&st);//栈不为空那就是false
    STDestroy(&st);
    return ret;
}


代码执行:

6c1e97480b4a48739173ea49379584be.png

  本文结束,若有错误,欢迎改正,谢谢支持!

相关文章
|
1月前
|
存储 安全 Java
JVM常见面试题(二):JVM是什么、由哪些部分组成、运行流程,JDK、JRE、JVM关系;程序计数器,堆,虚拟机栈,堆栈的区别是什么,方法区,直接内存
JVM常见面试题(二):JVM是什么、由哪些部分组成、运行流程是什么,JDK、JRE、JVM的联系与区别;什么是程序计数器,堆,虚拟机栈,栈内存溢出,堆栈的区别是什么,方法区,直接内存
JVM常见面试题(二):JVM是什么、由哪些部分组成、运行流程,JDK、JRE、JVM关系;程序计数器,堆,虚拟机栈,堆栈的区别是什么,方法区,直接内存
|
30天前
|
存储 设计模式 Java
Unity精华☀️ 面试“堆、栈”误区!这样做可能反而会降低吸引力
Unity精华☀️ 面试“堆、栈”误区!这样做可能反而会降低吸引力
|
21天前
|
存储 算法 索引
【面试题】最长有效括号
【面试题】最长有效括号
29 0
|
29天前
|
安全 Java
虚拟机栈的五道面试题
这篇文章提供了关于Java虚拟机栈的五个面试问题,涉及栈溢出的情况、栈大小调整、栈内存的分配、垃圾回收与虚拟机栈的关系以及局部变量的线程安全性。
|
2月前
|
存储 安全 Java
Java面试题:在JVM中,堆和栈有什么区别?请详细解释说明,要深入到底层知识
Java面试题:在JVM中,堆和栈有什么区别?请详细解释说明,要深入到底层知识
51 3
|
2月前
|
存储 缓存 监控
Java面试题:解释堆和栈的OutOfMemoryError通常在什么情况下会发生
Java面试题:解释堆和栈的OutOfMemoryError通常在什么情况下会发生
38 3
|
2月前
|
设计模式 安全 Java
Java面试题:请解释Java中的线程池以及为什么要使用线程池?请解释Java中的内存模型以及如何避免内存泄漏?请解释Java中的并发工具包以及如何实现一个简单的线程安全队列?
Java面试题:请解释Java中的线程池以及为什么要使用线程池?请解释Java中的内存模型以及如何避免内存泄漏?请解释Java中的并发工具包以及如何实现一个简单的线程安全队列?
35 1
|
2月前
|
存储 设计模式 监控
Java面试题:简述JVM的内存结构,包括堆、栈、方法区等。栈内存优化的方法有 哪些?
Java面试题:简述JVM的内存结构,包括堆、栈、方法区等。栈内存优化的方法有 哪些?
31 0
|
2月前
|
设计模式 安全 NoSQL
Java面试题:设计一个线程安全的单例模式,并解释其内存占用和垃圾回收机制;使用生产者消费者模式实现一个并发安全的队列;设计一个支持高并发的分布式锁
Java面试题:设计一个线程安全的单例模式,并解释其内存占用和垃圾回收机制;使用生产者消费者模式实现一个并发安全的队列;设计一个支持高并发的分布式锁
42 0
|
2月前
|
Java 开发者
Java面试题:Java内存管理精要与多线程协同策略,Java内存管理:堆内存、栈内存、方法区、垃圾收集机制等,多线程编程的掌握,包括线程创建、同步机制的原理
Java面试题:Java内存管理精要与多线程协同策略,Java内存管理:堆内存、栈内存、方法区、垃圾收集机制等,多线程编程的掌握,包括线程创建、同步机制的原理
26 0