美文网首页Android 面试专辑面试汇总ACM题库~
京东笔试题——括号匹配问题

京东笔试题——括号匹配问题

作者: 关玮琳linSir | 来源:发表于2017-09-09 12:03 被阅读187次

昨天朋友笔试,大家做着玩的题

首先,会给我们一个已经括号匹配的串,然后成对去掉,问有多少种情况,具体可以看一下下图。

java代码:

public class Main5 {

    static boolean isMatch(String s) {
        Stack<Character> sk = new Stack<Character>();
        for (int i = 0; i < s.length(); i++) {
            if (s.charAt(i) == '(') {
                sk.push('(');
            }
            if (s.charAt(i) == ')') {
                if (!sk.isEmpty() && sk.pop() == '(')
                    continue;
                else
                    return false;
            }
        }
        if (sk.isEmpty())
            return true;
        else
            return false;
    }

    public static String ArrayListToString(ArrayList<Character> list) {
        String result = "";
        for (int i = 0; i < list.size(); i++) {
            result += list.get(i);
        }
        return result;
    }

    public static int Dong2(String text) {
        int result = 1;
        int count = 0;
        int charsCount = text.length();
        char[] chars = text.toCharArray();
        int where = 0;

        ArrayList<Character> list = new ArrayList<Character>();
        for (int i = 0; i < charsCount; i++) {
            list.add(chars[i]);
        }
        while (list.contains('(')) {
            list.remove(0);
            for (int j = 0; j < list.size(); j++) {
                Character character = list.remove(j);
                if (isMatch(ArrayListToString(list))) {
                    count++;
                    where = j;
                }
                list.add(j, character);
            }
            list.remove(where);
            result = result * count;
            count = 0;
        }

        return result;
    }

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

    }

}

输出:

24
6
2
1

相关文章

  • 京东笔试题——括号匹配问题

    昨天朋友笔试,大家做着玩的题 首先,会给我们一个已经括号匹配的串,然后成对去掉,问有多少种情况,具体可以看一下下图...

  • 3. 一些算法问题

    1. 括号匹配问题 算法:括号匹配问题 - 简书 C程序括号匹配检查 - Jason ZHANG的博客 - CSD...

  • 括号匹配问题

    这个问题的描述很简单,就是若括号匹配则返回true,否则返回false。 Given a string conta...

  • 括号匹配问题

    问题描述 有效字符串需满足: 左括号必须用相同类型的右括号闭合。包括:“( )”,“[ ]”,“{ }”。左括号必...

  • 数据结构与算法 习题2

    1.括号匹配检验: (字节出现过的算法⾯试题/LeetCode) 假设表达式中允许包含两种括号:圆括号与⽅括号,其...

  • 栈、队列解决问题

    栈解决括号匹配问题 一个字符串中包含小括号、中括号、大括号,判断该字符串中的括号是否匹配 ()()[]{} 匹配...

  • chap3-栈和队列

    括号匹配问题 // 括号匹配,遇到 '\0' 结束// 遇到花、中、圆左括号进栈,遇到花、中、圆右括号检查栈顶元素...

  • 数据结构中使用指针运算括号匹配问题

    使用指针实现括号匹配问题:

  • 算法:括号匹配问题

    还记得有一次笔试题,有一道括号匹配的算法题,当时没有学习数据结构和算法,思路很模糊,后来了解一些数据结构之后就有思...

  • 判断括号匹配问题

    问题描述 给定一个字符串,其中的字符包含任意字符包括三种括号:花括号{ }、中括号[ ]、圆括号( )。设计算法,...

网友评论

    本文标题:京东笔试题——括号匹配问题

    本文链接:https://www.haomeiwen.com/subject/nqbojxtx.html