Java实现字符串检验合法性,Java实现检验给定字符串是否成对出现(栈解决)

思路:

1、将字符串的每个字符进行遍历

2、如果发现是左括号,那么将该字符压入到栈中

3、如果是右括号,先去存储好的栈顶找到相应的值

4、若栈为空返回false,若匹配,pop该左括号,若不匹配也返回false

5、最后看存储栈中的做括号是否都匹配上了,也就是栈最后为空,返回true,否则返回falsepublic class T3 {

public static void main(String[] args) {

System.out.println(isMatch("asdasdadasdasdsa"));

System.out.println(isMatch("{ada(ada)asdas}"));

System.out.println(isMatch("{asdasd(asdasdasd}asda)"));

}

static boolean isMatch(String s) {

if (null == s) {

return false;

}

//定义左右括号的对应关系

Map bracket = new HashMap<>();

bracket.put('(', ')');

bracket.put('{', '}');

bracket.put('[', ']');

Stack stack = new Stack<>();

char[] chars = s.toCharArray();

for (Character temp : chars) {

if (bracket.containsKey(temp)) {

stack.push(temp);

} else if (bracket.containsValue(temp)) {

if (stack.isEmpty()) {

return false;

}

if (bracket.get(stack.peek()).equals(temp)) {

stack.pop();

} else {

return false;

}

}

}

return stack.isEmpty();

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值