京東筆試題——括號(hào)匹配問(wèn)題

昨天朋友筆試,大家做著玩的題

首先,會(huì)給我們一個(gè)已經(jīng)括號(hào)匹配的串,然后成對(duì)去掉,問(wèn)有多少種情況,具體可以看一下下圖。

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
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢(shì)1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 179,062評(píng)論 25 709
  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語(yǔ)法,類相關(guān)的語(yǔ)法,內(nèi)部類的語(yǔ)法,繼承相關(guān)的語(yǔ)法,異常的語(yǔ)法,線程的語(yǔ)...
    子非魚(yú)_t_閱讀 34,727評(píng)論 18 399
  • 【生來(lái)堙滅星海,死后化作塵埃?!?后來(lái) 一些跌撞的時(shí)光 釀成了十八年的女兒紅 你醉在酒里 無(wú)人喚醒 黃昏贈(zèng)與你的千...
    亦弋閱讀 214評(píng)論 0 0
  • #幸福是需要修出來(lái)的~每天進(jìn)步1%~幸福實(shí)修13班~08李玉珍# 20171128(1/60) 【幸福三朵玫瑰】 ...
    stx2010閱讀 158評(píng)論 3 0
  • 目錄 黎浩對(duì)我述說(shuō)往事的那天,本應(yīng)是他與喬生慶祝他們?cè)谝黄鸢偬旒o(jì)念的日子。我們?cè)谝患倚〔宛^里相對(duì)而坐,桌上擺滿了酒...
    dd仔閱讀 1,235評(píng)論 5 4

友情鏈接更多精彩內(nèi)容