'   括号检查

'     括号共有四种:  1(英文圆括号),2(中文圆括号),3[方括号],4{花括号}

'      要左右匹配(可以嵌套)

Private Shared Function isBracketsOK(strInput As String) As Boolean

'  四种括号,左右各一个,共8个

Dim brace1_open As Char = "("

Dim brace1_close As Char = ")"

Dim brace2_open As Char = "("

Dim brace2_close As Char = ")"

Dim brace3_open As Char = "["

Dim brace3_close As Char = "]"

Dim brace4_open As Char = "{"

Dim brace4_close As Char = "}"

'  四个左括号的列表

Dim list_braceOpen As List(Of Char) = New List(Of Char)

list_braceOpen.Add(brace1_open)

list_braceOpen.Add(brace2_open)

list_braceOpen.Add(brace3_open)

list_braceOpen.Add(brace4_open)

'  四个右括号的列表

Dim list_braceClose As List(Of Char) = New List(Of Char)

list_braceClose.Add(brace1_close)

list_braceClose.Add(brace2_close)

list_braceClose.Add(brace3_close)

list_braceClose.Add(brace4_close)

'   左括号 和 右括号 的一一对应关系,用字典表示

Dim dic_braces As Dictionary(Of Char, Char) = New Dictionary(Of Char, Char)

dic_braces.Add(brace1_open, brace1_close)

dic_braces.Add(brace2_open, brace2_close)

dic_braces.Add(brace3_open, brace3_close)

dic_braces.Add(brace4_open, brace4_close)

'  右括号 组成的 堆栈(先进后出)

Dim stack_close As Stack(Of Char) = New Stack(Of Char)

Dim CharArr As Char() = strInput.ToCharArray()   '  将字符串转为 字符数组

For Each _char In CharArr    '  对于每个字符

If list_braceOpen.Contains(_char) Then   '   如果这是个 左括号

stack_close.Push(dic_braces(_char))                             '  在 堆栈中 加入相应的 右括号

ElseIf list_braceClose.Contains(_char) Then   ' 如果这是个  右括号

If stack_close.Count = 0 Then   '   如果 堆栈 已经空了(不能pop了)

Return False   '  报错

EndIf

Dim charPop AsChar = stack_close.Pop()   '  从 堆栈中取得一个右括号

If _char <> charPop Then     '  如果 从堆栈中取得的右括号 和 这个右括号 不同

Return False     '   报错

End If

End If

Next

If stack_close.Count > 0 Then   '  如果堆栈中还有 右括号

Return False

End  If

Return  True

End  Function

vb.net 对字符串中的括号匹配进行判断,容许嵌套的更多相关文章

  1. 华为OJ:2199 推断输入字符串中的括号匹配

    依据不同的括号有个计数器.在遍历时.当计数器小于0则返回false或者当遍历完后,计数器仍旧不为零,也返回false. import java.util.Scanner; public class b ...

  2. Excel-判断一个文本字符串中是否包含数字! 判断一个文本字符串是否是纯汉字!

    0.判断一个文本字符串中是否包含数字!/判断一个文本字符串是否是纯汉字! 公式=IF(LENB(A1)=2*LEN(A1),"都是汉字","含有非汉字字符") ...

  3. python栈--字符串反转,括号匹配

    栈的实现: # 定义一个栈类 class Stack(): # 栈的初始化 def __init__(self): self.items = [] # 判断栈是否为空,为空返回True def isE ...

  4. php使用正则表达式提取字符串中尖括号、小括号、中括号、大括号中的字符串

    $str="你好<我>(爱)[北京]{天安门}"; echo f1($str); //返回你好 echo f2($str); //返回我 echo f3($str); ...

  5. js正则实现从一段复杂html代码字符串中匹配并处理特定信息

    js正则实现从一段复杂html代码字符串中匹配并处理特定信息 问题: 现在要从一个复杂的html代码字符串(包含各种html标签,数字.中文等信息)中找到某一段特别的信息(被一对“|”包裹着),并对他 ...

  6. java:数据结构(二)栈的应用(括号匹配)

    一.什么是括号匹配: 括号匹配就是利用计算机辨别表达式里面的括号是否书写成功 例如: {()((a)) }这就是一个正确 (()()   这就是一个错误的 二.括号匹配的算法: 众所周知,括号分为花括 ...

  7. DP_括号匹配序列问题

    括号匹配问题 简单括号匹配问题是给出字符串,判断字符串中的括号是否匹配,此类问题核心解决方案就是利用栈的后进先出的特性,从左到右依次遍历字符串,遇左括号进栈,遇右括号将其与栈顶元素配对,若能配对,则栈 ...

  8. 华为笔试——C++括号匹配

    题目:括号匹配 题目来源:https://blog.csdn.net/lizi_stdio/article/details/76618908 题目介绍:输入一个字符串,里面可能包含“()”.“ [   ...

  9. JS中删除字符串中的空格

    问题描述:         在进行字符串操作时,由于字符串中存在较多的空格,因此需要考虑取消字符串中的空格 问题解决:       (1)删除字符串中的前导空格(字符串的前面的空格): 注意:这里使用 ...

随机推荐

  1. jax-rs 标准以及 结合 resteasy的使用

    jax-rs:https://baike.baidu.com/item/JAX-RS/10914743?fr=aladdin resteasy:https://www.iteye.com/blog/s ...

  2. Caused by: java.lang.ClassCastException: org.springframework.web.SpringServletContainerInitializer cannot be cast to javax.servlet.ServletContainerInitializer。。。。。检查一下servlet-api是否冲突了?

    原因:jar包发生冲突.在我的pom.xml文件中 <dependency>      <groupId>javax.servlet</groupId>       ...

  3. WPF 精修篇 非UI进程后台更新UI进程

    原文:WPF 精修篇 非UI进程后台更新UI进程 <Grid> <Grid.RowDefinitions> <RowDefinition Height="11* ...

  4. 安全漏洞系列(二)---站点信息侦测(C# MVC)

    参考地址:https://jingyan.baidu.com/article/77b8dc7fa657c26174eab631.html 概述:站点信息侦测漏洞会检测到用的版本信息等,然后借此进行一些 ...

  5. loadrunner11 您不具有该 Vuser 类型的许可证. 请与 HP Software 联系以更新许可证.

    您不具有该 Vuser 类型的许可证. 请与 HP Software 联系以更新许可证. 在loadrunner11 执行发生报错: 打开loadrunner软件首页,点击配置-->loadru ...

  6. HTML中的音频 视频 的播放代码

    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/ ...

  7. Jenkins 显示语言-英文切换中文

    1.进入插件管理 搜索 Locale 插件并进行安装 2.插件安装成功后进入系统设置 3.在 Locale 中 Default Language 字段填入 zh_CN 并且勾选 Ignore brow ...

  8. Java 之 JDK 1.8 新增日期时间类型

    一.原来的日期时间 Java1.0中包含了一个Date类,但是它的大多数方法已经在Java 1.1引入Calendar类之后被弃用了.而Calendar并不比Date好多少.它们面临的问题是: ① 可 ...

  9. There is already an open DataReader associated with this Command which must be closed first

    通常出现在嵌套查询数据库(比如在一个qry的遍历时,又进行了数据库查询) 通过在连接字符串中允许MARS可以轻松解决这个问题. 将MultipleActiveResultSets = true添加到连 ...

  10. UDP基础

    UDP主要特点: (1)UDP是无连接的,发送数据不需要建立连接,减少了开销和发送数据之前的时延. (2)UDP使用尽最大努力交付,即不保证可靠交付,因此主机不需要维持连接状态表. (3)UDP面向报 ...