2021-10-27删除非法的括号

使用 boolean valid(String s) 判断字符串 s 是否是合法的括号字符串。

public static boolean isValid(String s) {
int l = 0;
for (int i = 0; i < s.length(); i++) {
	int temp = s.charAt(i);
	if (temp == '(')
		l++;
	else if (temp == ')') {
		if (l > 0)
			l--;
		else
			return false;
	}
}
return l == 0;
}


然后暴力遍历所有可以裁剪的情况。
将裁剪后的字符串和中间过程字符串存放在一个队列中,若裁剪后得到的字符串是合法的括号字符串,则将其放入结果集合中,若裁剪后仍不合法,则放入队列中继续迭代。
 

while (!queue.isEmpty()) {  // 如果队列非空
	String temp = queue.poll();
	if (isValid(temp)) {
		result.add(temp);
		found = true;
	}
	if (found)// 推出裁剪,不再进一步裁剪,保证最少的更改次数
		continue;
	// 裁剪
	for (int i = 0; i < temp.length(); i++) {
		if (temp.charAt(i) == '(' || temp.charAt(i) == ')') {   // 对括号进行裁剪
			String str; // 裁剪后的字符串
			if (i == temp.length()-1) {
				str = temp.substring(0, temp.length()-1);
			} else {
				str = temp.substring(0, i) + temp.substring(i+1);
			}
			if (set.add(str)) { 
				// 如果集合中还没有出现过该字符串,则添加进队列
				queue.offer(str);
			}
		}
	}
}

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值