转载请注明出处:

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

  有效字符串需满足:

    左括号必须用相同类型的右括号闭合。
    左括号必须以正确的顺序闭合。
    注意空字符串可被认为是有效字符串。

  示例 1:

    输入: "()"
    输出: true
  示例 2:

    输入: "()[]{}"
    输出: true
  示例 3:

    输入: "(]"
    输出: false
  示例 4:

    输入: "([)]"
    输出: false
  示例 5:

    输入: "{[]}"
    输出: true

用两种方法实现:

  

 1 import java.util.HashMap;
2 import java.util.Map;
3 import java.util.Stack;
4
5 /**
6 * 判断有效字符串
7 */
8 public class EffectiveString {
9 /**
10 * 给定一个只包括 '(',')','{','}','[',']' 的字符串,判断字符串是否有效。
11 * <p>
12 * 有效字符串需满足:
13 * <p>
14 * 左括号必须用相同类型的右括号闭合。
15 * 左括号必须以正确的顺序闭合。
16 * 注意空字符串可被认为是有效字符串。
17 *
18 * @param args
19 */
20 public static void main(String[] args) {
21 // 字符串有效时,两个特殊符号进行相互的匹配
22 boolean result1 = isValid1("()[]{}");
23 System.out.println(result1);
24 boolean result2 = isValid2("()[]{}");
25 System.out.println(result2);
26 }
27
28 public static boolean isValid1(String testStr) {
29 testStr = testStr.replaceAll("\\(\\)", "");
30 testStr = testStr.replaceAll("\\[\\]", "");
31 testStr = testStr.replaceAll("\\{\\}", "");
32 System.out.println(testStr);
33 char[] charArr = {'(', ')', '{', '}', '[', ']'};
34 for (int i = 0; i < charArr.length; i++) {
35 int num = testStr.indexOf(charArr[i]);
36 System.out.println(num);
37 if (num > 0) {
38 return false;
39 }
40 }
41 return true;
42 }
43
44 public static boolean isValid2(String str) {
45 Stack<Character> stack = new Stack<>();
46 Map<Character, Character> symbolMap = new HashMap<>();
47 symbolMap.put(']', '[');
48 symbolMap.put(')', '(');
49 symbolMap.put('}', '{');
50 char[] charArray = str.toCharArray();
51 for (int i = 0; i < charArray.length; i++) {
52 if (charArray[i] == '[' || charArray[i] == '(' || charArray[i] == '{') {
53 stack.push(charArray[i]);
54 } else {
55 Character value = symbolMap.get(charArray[i]);
56 if (stack.isEmpty()) {
57 return false;
58 }
59 if (value != stack.pop()) {
60 return false;
61 }
62 }
63 }
64 System.out.println(stack);
65 return stack.isEmpty();
66 }
67
68 }

  

Java 有效字符串判断的更多相关文章

  1. java String字符串判断

    判断空字符串:StringUtils.isBlank StringUtils.isBlank(null) = true StringUtils.isBlank("") = true ...

  2. java中字符串的非空判断

    问题如下:在java 中 字符串为null 如何判断String str;if(str==null) ??str.equal("null") ?? 答:我觉得应该搞清楚字符串对象和 ...

  3. Java空字符串与null的区别和判断字符串是否为空的方法

    Java空字符串与null的区别: 1.类型null表示的是一个对象的值,而并不是一个字符串.例如声明一个对象的引用,String a = null ;""表示的是一个空字符串,也 ...

  4. Java 中字两个字符串判断是否相等(转载)

    java中判断字符串是否相等有两种方法:1.用"=="运算符,该运算符表示指向字符串的引用是否相同,比如: String a="abc";String b=&q ...

  5. Java String字符串/==和equals区别,str。toCharAt(),getBytes,indexOf过滤存在字符,trim()/String与StringBuffer多线程安全/StringBuilder单线程—— 14.0

    课程概要 String 字符串 String字符串常用方法 StringBuffer StringBuilder String字符串: 1.实例化String对象 直接赋值  String str=& ...

  6. Java:字符串类String的功能介绍

    在java中,字符串是一个比较常用的类,因为代码中基本上处理的很多数据都是字符串类型的,因此,掌握字符串类的具体用法显得很重要了. 它的主要功能有如下几种:获取.判断.转换.替换.切割.字串的获取.大 ...

  7. Java入门篇(五)——Java的字符串/String类

    前面在举例时有出现过String的例子,当时肯定有一部分朋友不知道这个是做什么用的.其实String类是Java中一个比较特殊的类,字符串即String类,它不是Java的基本数据类型之一,但可以像基 ...

  8. java 二进制数字符串转换工具类

    java 二进制数字符串转换工具类 将二进制转换成八进制 将二进制转换成十进制 将二进制转换成十六进制 将十进制转换成二进制 package com.iteye.injavawetrust.ad; i ...

  9. Java进阶(二十一)java 空字符串与null区别

    java 空字符串与null区别 1.类型 null表示的是一个对象的值,而并不是一个字符串.例如声明一个对象的引用,String a = null ; ""表示的是一个空字符串, ...

  10. 由一篇吐槽对String空字符串判断的文章所引发的碎碎念

    一.起因 最近有篇关于String空字符串判断的文章火了,老是看到这篇文章,既然如此我也只好认真看了下:程序员晒出一段代码引来无数网友狂喷!网友:你就活该当码农! 我也觉得这段代码写的不怎么的,首先程 ...

随机推荐

  1. Tensorflow2.0实战之GAN

    本文主要带领读者了解生成对抗神经网络(GAN),并使用提供的face数据集训练网络 GAN 入门 自 2014 年 Ian Goodfellow 的<生成对抗网络(Generative Adve ...

  2. flask中使用pyjwt

    **pyjwt使用教程: ** https://pyjwt.readthedocs.io/en/stable/ 使用案例 import datetime from flask import Flask ...

  3. 【笔记整理】忽略https证书校验

    import requests url = "https://sam.huat.edu.cn:8443/selfservice/" # 默认不忽略ssl证书,如果有证书问题的网站会 ...

  4. 前端异步编程 —— Promise对象

    在前端编程中,处理一些简短.快速的操作,在主线程中就可以完成. 但是,在处理一些耗时比较长以至于比较明显的事情,比如读取一个大文件或者发出一个网络请求,就需要异步编程来实现,以避免只用主线程时造成页面 ...

  5. dtd的三种引入方式

  6. linux安装redis、ununtu和centos等类似的发行版安装redis,完全离线安装reids,自定义版本redis

    redis各个版本源码包下载:Index of /releases/ (redis.io) 下载与解压 从Index of /releases/ (redis.io)选择自己需要的版本并下载(此处以r ...

  7. 使用IO流写一个随机点名程序

    前言 最近学习了关于IO流的一些知识点,但是应用还不够,所以今天做个简单案例: 随机创建名字导入文件中: package ioandcollection; import java.io.Buffere ...

  8. 手动实现BERT

      本文重点介绍了如何从零训练一个BERT模型的过程,包括整体上BERT模型架构.数据集如何做预处理.MASK替换策略.训练模型和保存.加载模型和测试等. 一.BERT架构   BERT设计初衷是作为 ...

  9. 10个安全问题带你了解OWASP 定义的大模型应用

    摘要:OWASP 的一群研究人员,总结目前大模型中可能存在的TOP10安全风险,很好的揭示了我们在大模型应用中需要防护的目标,以及如何采取相应的防护措施. 本文分享自华为云社区<OWASP 定义 ...

  10. storybook插件说明: integrations与addons推荐

    官方的: https://storybook.js.org/integrations/ https://github.com/storybookjs/storybook/blob/master/ADD ...