需求:給定一個由括號([{)]}其中之一或多個組成的字符串判斷是否符合左右括號成對標準,不一樣括號可任意嵌套java
只有單個左或右括號 均不符合
)(、}{、][ 不符合
(){}[] 符合
({[]}) 符合
({}[)] 符合
()() 符合 左括號位置:0 2 右括號位置:1 3
(()) 符合 左括號位置: 0 1 右括號位置:2 3
((()))(()()) 符合 左括號位置:0 1 2 6 7 9 右括號位置:3 4 5 8 10 11
符合返回true,不然爲false
({[{]}}{}())
(())+{{}}{}+[] 其實最終與是否嵌套是無關的
左右括號個數相等且左括號所在的最大位置比右括號所在的最大位置小即符合測試
源代碼以下MatchTest.java:spa
package com.test.zhipengs; /** * A Question * 給定一個由括號([{)]}其中之一或多個組成的字符串判斷是否符合左右括號成對標準,不一樣括號可任意嵌套 * 只有單個左或右括號 均不符合 * )(、}{、][ 不符合 * (){}[] 符合 * ({[]}) 符合 * ({}[)] 符合 * ()() 符合 左括號位置:0 2 右括號位置:1 3 * (()) 符合 左括號位置: 0 1 右括號位置:2 3 * ((()))(()()) 符合 左括號位置:0 1 2 6 7 9 右括號位置:3 4 5 8 10 11 * 符合返回true,不然爲false * ({[{]}}{}()) * (())+{{}}{}+[] 其實最終與是否嵌套是無關的 * 左右括號個數相等且左括號所在的最大位置比右括號所在的最大位置小即符合 * * @author zhipengs * */ public class MatchTest { /** * main方法 * @param args */ public static void main(String[] args) { // 測試isMatch(String str)方法 String str1 = "("; System.out.println(str1+" ===== "+isMatch(str1)); String str2 = "["; System.out.println(str2+" ===== "+isMatch(str2)); String str3 = "{"; System.out.println(str3+" ===== "+isMatch(str3)); System.out.println("----------------------------"); String str4 = ")"; System.out.println(str4+" ===== "+isMatch(str4)); String str5 = "]"; System.out.println(str5+" ===== "+isMatch(str5)); String str6 = "}"; System.out.println(str6+" ===== "+isMatch(str6)); System.out.println("----------------------------"); String str7 = ")("; System.out.println(str7+" ===== "+isMatch(str7)); String str8 = "]["; System.out.println(str8+" ===== "+isMatch(str8)); String str9 = "}{"; System.out.println(str9+" ===== "+isMatch(str9)); System.out.println("----------------------------"); String str10 = "))"; System.out.println(str10+" ===== "+isMatch(str10)); String str11 = "[["; System.out.println(str11+" ===== "+isMatch(str11)); System.out.println("----------------------------"); String str12 = "()"; System.out.println(str12+" ===== "+isMatch(str12)); String str13 = "[[]]"; System.out.println(str13+" ===== "+isMatch(str13)); String str14 = "{}{}"; System.out.println(str14+" ===== "+isMatch(str14)); System.out.println("----------------------------"); String str15 = "(()())()"; System.out.println(str15+" ===== "+isMatch(str15)); String str16 = "[({}{()})]"; System.out.println(str16+" ===== "+isMatch(str16)); String str17 = "{({[})}]"; System.out.println(str17+" ===== "+isMatch(str17)); } /** * 具體的判斷是否符合標準的方法 * @param str * @return boolean */ private static boolean isMatch(String str) { boolean isMatch = false; int len = str.length(); if (null == str || len <= 1) { return isMatch; } char[] charArray = str.toCharArray(); int smallLeft = 0, smallRight = 0, midLeft = 0, midRight = 0, bigLeft = 0, bigRight = 0; for (int i = 0; i < len; i++) { switch (charArray[i]) { case '(': smallLeft++; break; case ')': smallRight++; break; case '[': midLeft++; break; case ']': midRight++; break; case '{': bigLeft++; break; case '}': bigRight++; break; default: break; } } if ((smallLeft == smallRight) && str.lastIndexOf("(") <= str.lastIndexOf(")")) { isMatch = true; } if ((midLeft == midRight) && isMatch && str.lastIndexOf("[") <= str.lastIndexOf("]")) { isMatch = true; } else { isMatch = false; } if ((bigLeft == bigRight) && isMatch && str.lastIndexOf("{") <= str.lastIndexOf("}")) { isMatch = true; } else { isMatch = false; } return isMatch; } }
main方法輸出結果以下:code
( ===== false
[ ===== false
{ ===== false
----------------------------
) ===== false
] ===== false
} ===== false
----------------------------
)( ===== false
][ ===== false
}{ ===== false
----------------------------
)) ===== false
[[ ===== false
----------------------------
() ===== true
[[]] ===== true
{}{} ===== true
----------------------------
(()())() ===== true
[({}{()})] ===== true
{({[})}] ===== trueblog
總結:只要瞭解字符串中最後面一個某特定字符所在的位置的方法lastIndexOf()以及對判斷是否符合的條件分析出來便可完成需求---坑跌的鄙視!ip