这篇文章给大家分享的是有关Java中括号匹配问题的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。
题目来自Leetcode中国
给定一个只包括 (,),{,},[,] 的字符串,判断字符串是否有效。
有效字符串需满足:
1、左括号必须用相同类型的右括号闭合。
2、左括号必须以正确的顺序闭合。
注意空字符串可被认为是有效字符串。
示例 1:
输入: “()”
输出: true
示例 2:
输入: “()[]{}”
输出: true
示例 3:
输入: “(]”
输出: false
示例 4:
输入: “([)]”
输出: false
示例 5:
输入: “{[]}”
输出: true
S1:遍历输入的括号序列,如果是左括号,进入S2,如果是右括号,进入S3
S2:如果当前遍历到左括号,则入栈
S3:如果当前遍历到右括号,则出栈一个元素,看其是否与当前的右括号组成一对,如果不是,则匹配失败。或者在出栈过程中发生异常(从空栈中出栈),也匹配失败
S4:若能顺利遍历完成,检查栈中是否还有剩余元素,如果有,则匹配失败;如果没有,则匹配成功。
下面以(({[]}) 序列为例说明算法过程:
1、首先将这个字符串转换成字符数组,并初始化一个空栈。
2、遍历到第0个元素,(,为左括号,入栈
3、后面以此类推,遍历完第3个元素[后,栈空间应该是这样的
4、遍历到第4个元素]时,发现为右括号,此时,从栈顶出栈一个左括号,即[,刚好[与],匹配成一对
5、以此类推,直到第6个元素),都是匹配的
6、此时,序列已经遍历完毕,但是栈不是空的,所以原序列匹配失败。
这里我使用了链栈,链表就没有自己写了,用了Java现成的LinkedList<T>
/**
* 栈类,这里使用链栈
*/
class MyStack{
private int num;
private LinkedList<Character> data;
public MyStack(){
this.num = 0;
data = new LinkedList<Character>();
}
/**
* 判断栈是否为空
* @return
*/
public boolean isEmpty(){
return num == 0 ? true : false;
}
/**
* 入栈
* @param ch
*/
public void push(Character ch){
this.data.add(ch);
this.num++;
}
/**
* 出栈
* @return
*/
public Character pop(){
//栈为空时,返回' '
if(this.isEmpty()){
return ' ';
}
Character ch = this.data.remove(data.size()-1);
this.num--;
return ch;
}
}
/**
* 核心方法
* @param s
* @return
*/
public boolean isValid(String s) {
char[] temp = s.toCharArray();
MyStack stack = new MyStack();
boolean flag = true;
for(int i = 0 ; i < temp.length ; i++){
//左括号,入栈
if(temp[i] == '(' || temp[i] == '{' || temp[i] == '['){
stack.push(temp[i]);
}
else{
//右括号,出栈
char left = stack.pop();
//如果从栈中取出空值,说明栈已空,但还有右括号存在,肯定不匹配
if(left == ' ') {
flag = false;
}
//如果左右括号不匹配,则失败
if(!check(left,temp[i])){
flag = false;
}
}
}
//循环完毕后,若栈不空,说明左括号个数大于右括号,不匹配
if(flag){
if(!stack.isEmpty()){
flag = false;
}
}
return flag;
}
}
import java.util.LinkedList;
/**
* 括号匹配问题(Blog)
*/
/**
* 栈类,这里使用链栈
*/
class MyStack{
private int num;
private LinkedList<Character> data;
public MyStack(){
this.num = 0;
data = new LinkedList<Character>();
}
/**
* 判断栈是否为空
* @return
*/
public boolean isEmpty(){
return num == 0 ? true : false;
}
/**
* 入栈
* @param ch
*/
public void push(Character ch){
this.data.add(ch);
this.num++;
}
/**
* 出栈
* @return
*/
public Character pop(){
//栈为空时,返回' '
if(this.isEmpty()){
return ' ';
}
Character ch = this.data.remove(data.size()-1);
this.num--;
return ch;
}
}
class Solution {
/**
* 判定左右括号是否匹配
* @param left
* @param right
* @return
*/
private boolean check(char left , char right){
if(left == '('){
return right == ')' ? true : false;
}
if(left == '['){
return right == ']' ? true : false;
}
if(left == '{'){
return right == '}' ? true : false;
}
return false;
}
/**
* 核心方法
* @param s
* @return
*/
public boolean isValid(String s) {
char[] temp = s.toCharArray();
MyStack stack = new MyStack();
boolean flag = true;
for(int i = 0 ; i < temp.length ; i++){
//左括号,入栈
if(temp[i] == '(' || temp[i] == '{' || temp[i] == '['){
stack.push(temp[i]);
}
else{
//右括号,出栈
char left = stack.pop();
//如果从栈中取出空值,说明栈已空,但还有右括号存在,肯定不匹配
if(left == ' ') {
flag = false;
}
//如果左右括号不匹配,则失败
if(!check(left,temp[i])){
flag = false;
}
}
}
//循环完毕后,若栈不空,说明左括号个数大于右括号,不匹配
if(flag){
if(!stack.isEmpty()){
flag = false;
}
}
return flag;
}
}
public class Main {
public static void main(String[] args) {
// write your code here
Solution solution = new Solution();
System.out.println(solution.isValid("(({[]})"));
}
}
(({[]})的运行结果
false
Process finished with exit code 0
与我们之前预测的一致。
感谢各位的阅读!关于“Java中括号匹配问题的示例分析”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。