括號匹配(二)

2022-05-05 08:51:12 字數 991 閱讀 9693

時間限制:1000 ms  |  記憶體限制:65535 kb

難度:6

描述給你乙個字串,裡面只包含"(",")","[","]"四種符號,請問你需要至少新增多少個括號才能使這些括號匹配起來。

如:是匹配的

()是匹配的

((]是不匹配的

([)]是不匹配的

輸入第一行輸入乙個正整數n,表示測試資料組數(n<=10)

每組測試資料都只有一行,是乙個字串s,s中只包含以上所說的四種字元,s的長度不超過100

輸出對於每組測試資料都輸出乙個正整數,表示最少需要新增的括號的數量。每組測試輸出佔一行

樣例輸入

4

()((]

([)]

樣例輸出

003

2先給出我的錯誤答案

基本思路就是利用棧的思想,從左到右遍歷右括號,檢查右括號的前乙個括號是否匹配,匹配的話就成對刪去,不匹配就新增括號。遍歷一遍後,新增的個數再加上最後剩下未匹配的左括號數。

#includeusing

namespace

std;

int check(const

char*str)

else

if(*(iter - 1) != '('

)

else

}else

if(i == ']'

)

else

if(*(iter - 1) != '['

)

else

}else

iter++;

}ret +=ope.length();

return

ret;

}int

main()

有明顯的錯誤,比如 [(]]]]就錯誤了。。。待明天研究

括號匹配(二)

時間限制 1000 ms 記憶體限制 65535 kb 難度 6 描述 給你乙個字串,裡面只包含 四種符號,請問你需要至少新增多少個括號才能使這些括號匹配起來。如 是匹配的 是匹配的 是不匹配的 是不匹配的 輸入第一行輸入乙個正整數n,表示測試資料組數 n 10 每組測試資料都只有一行,是乙個字串s...

括號匹配(二)

題目 問題 給你乙個字串,裡面只包含 四種符號,請問你需要至少新增多少個括號才能使這些括號匹配起來。如 是匹配的,所需括號個數為 0.是匹配的,所需括號個數為 0.是不匹配的,所需最少括號個數為 3.是不匹配的,所需最少括號個數為 2.分析 此題來自 作者同時給出了正確答案。但是,感覺答案還不是特別...

括號匹配(二)

演算法 動態規劃 描述給你乙個字串,裡面只包含 四種符號,請問你需要至少新增多少個括號才能使這些括號匹配起來。如 是匹配的 是匹配的 是不匹配的 是不匹配的 輸入第一行輸入乙個正整數n,表示測試資料組數 n 10 每組測試資料都只有一行,是乙個字串s,s中只包含以上所說的四種字元,s的長度不超過10...