zoukankan      html  css  js  c++  java
  • 蓝桥杯-括号问题-java

    /* (程序头部注释开始)

    * 程序的版权和版本声明部分

    * Copyright (c) 2016, 广州科技贸易职业学院信息工程系学生 

    * All rights reserved.

    * 文件名称: 蓝桥杯赛题                           

    * 作    者:   彭俊豪               

    * 完成日期:   2016   年 04月 01日

    * 版 本 号:      001   

    * 对任务及求解方法的描述部分

    * 输入描述: 

    * 问题描述:

    下面的代码用于判断一个串中的括号是否匹配
    所谓匹配是指不同类型的括号必须左右呼应,可以相互包含,但不能交叉

    例如:
    ..(..[..]..).. 是允许的
    ..(...[...)....].... 是禁止的
    对于 main 方法中的测试用例,应该输出:
    false
    true
    false
    false

    import java.util.*;
    public class A22
    {
    public static boolean isGoodBracket(String s)
    {
    Stack<Character> a = new Stack<Character>();

    for(int i=0; i<s.length(); i++)
    {
    char c = s.charAt(i);
    if(c=='(') a.push(')');
    if(c=='[') a.push(']');
    if(c=='{') a.push('}');

    if(c==')' || c==']' || c=='}')
    {
    if(____________________) return false; // 填空
    if(a.pop() != c) return false;
    }
    }

    if(___________________) return false; // 填空

    return true;
    }

    public static void main(String[] args)
    {
    System.out.println( isGoodBracket("...(..[.)..].{.(..).}..."));
    System.out.println( isGoodBracket("...(..[...].(.).){.(..).}..."));
    System.out.println( isGoodBracket(".....[...].(.).){.(..).}..."));
    System.out.println( isGoodBracket("...(..[...].(.).){.(..)...."));
    }
    }

    * 程序输出:

    * 程序头部的注释结束

    */

    上代码:

        if(a.empty()) return false; // 填空

     

        if(!a.empty()) return false;  // 填空

     

     

  • 相关阅读:
    脊椎有问题的7个信号
    SOHO兼职 SOHO一族 世界创业实验室
    MSTParser句法工具使用方法
    BinaryFormatter序列化实例
    C#中文件流,网络流,缓冲流等流的概念理解
    探讨和比较Java和_NET的序列化_Serialization_框架
    .net中对象序列化技术浅谈
    史上最详细最容易理解的HMM文章
    成功者足迹的综合总结:网络创业14条不外传的绝招
    此情何时休
  • 原文地址:https://www.cnblogs.com/pengjunhao/p/6668082.html
Copyright © 2011-2022 走看看