java括號匹配問題介紹
題目描述:
給定一個(gè)只包括 ‘(',')','{','}','[',']' 的字符串 s ,判斷字符串是否有效。
有效字符串需滿足:
左括號必須用相同類型的右括號閉合。
左括號必須以正確的順序閉合
題目鏈接:括號匹配問題
問題分析:
1 可能存在左括號多的情況

2 可能存在右括號多的情況

3 存在括號不匹配的情況

總結(jié)解題思路:
1 我們在遍歷字符串的過程中,需要先取得棧頂?shù)脑嘏c右括號比較,看是否匹配,如果匹配才能出棧。
2 在出棧的過程中,如果棧為空,說明右括號多了,如果發(fā)現(xiàn)棧頂元素與右括號不是匹配的括號,那么就需要直接return了
3 在整個(gè)字符串遍歷結(jié)束之后,我們要判斷一下棧是否為空,如果為空,說明是匹配的,否則就是左括號偏多的情況。
代碼實(shí)現(xiàn):
public boolean isValid(String s) {
Stack<Character> stack = new Stack<>();
for(int i = 0;i<s.length();i++){
char ch = s.charAt(i);
if(ch=='('||ch=='['||ch=='{'){
stack.push(ch);//左括號進(jìn)棧
}else{
if(stack.empty()){//棧為空,右括號多了
return false;
}else{
char ch1 = stack.peek();//取棧頂元素
if(ch1=='('&& ch ==')'||ch1=='{'&&ch=='}'||ch1=='['&&ch==']'){
stack.pop();//匹配出棧
}else{
return false;//括號不匹配
}
}
}
}
if(!stack.empty()){
return false;//棧不為空,左括號偏多了
}
return true;
}
到此這篇關(guān)于java括號匹配問題介紹的文章就介紹到這了,更多相關(guān)java括號匹配內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java+MyBatis+MySQL開發(fā)環(huán)境搭建流程詳解
Java的MyBatis框架提供了強(qiáng)大的數(shù)據(jù)庫操作支持,這里我們先在本地的開發(fā)環(huán)境中上手,來看一下Java+MyBatis+MySQL開發(fā)環(huán)境搭建流程詳2016-06-06
maven自動將源碼打包并發(fā)布的實(shí)現(xiàn)步驟
maven-source-plugin 提供項(xiàng)目自動將源碼打包并發(fā)布的功能,在需要發(fā)布源碼項(xiàng)目的 pom.xml 文件中添加即可,本文就來介紹一下如何設(shè)置,感興趣的可以了解一下2023-11-11
使用springboot在工具類中讀取配置文件(ClassPathResource)
這篇文章主要介紹了使用springboot在工具類中讀取配置文件(ClassPathResource),具有很好的參考價(jià)值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-08-08
Java基于分治法實(shí)現(xiàn)的快速排序算法示例
這篇文章主要介紹了Java基于分治法實(shí)現(xiàn)的快速排序算法,結(jié)合實(shí)例形式分析了java基于分治法的快速排序相關(guān)實(shí)現(xiàn)技巧,代碼中備有較為詳細(xì)的注釋說明便于理解,需要的朋友可以參考下2017-12-12

