首页 > 代码库 > java 实例 判断输出的括号是否成对出现
java 实例 判断输出的括号是否成对出现
输入:
{}()
({()})
{}(
[]
输出:
true true false true
代码:
import java.util.Scanner; import java.util.Stack; import java.util.HashMap; class Solution { public static void main(String[] args) { /* Create HashMap to match opening & closing brackets */ HashMap<Character, Character> map = new HashMap<>(); map.put(‘(‘, ‘)‘); map.put(‘[‘, ‘]‘); map.put(‘{‘, ‘}‘); /* Test each expression for validity */ Scanner scan = new Scanner(System.in); while (scan.hasNext()) { String expression = scan.next(); System.out.println(isBalanced(expression, map) ? "true" : "false" ); } scan.close(); } public static boolean isBalanced(String expression, HashMap<Character, Character> map) { /* Odd length strings are not balanced */ if ((expression.length() % 2) != 0) { return false; } Stack<Character> stack = new Stack<>(); for (int i = 0; i < expression.length(); i++) { Character ch = expression.charAt(i); if (map.containsKey(ch)) { stack.push(ch); } else if (stack.isEmpty() || ch != map.get(stack.pop())) { return false; } } return stack.isEmpty(); } }
java 实例 判断输出的括号是否成对出现
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。