NYOJ 括號匹配(二)

2021-08-04 09:24:09 字數 1325 閱讀 7272

題意:

給你幾對括號,讓你看一下括號是否配對,輸出最少新增多少個括號可以使括號配對

這道題和括號配對(一)不一樣,剛開始我也想用棧試試看能不能,但是如何記錄需要新增多少對括號?

如果用最後棧裡還有多少元素沒出棧那是不行的,比如  [  (  ]  )   在棧裡剩餘是4個,其實只需要2個括號就行了

那麼只有用別的方法了

這題是一道區間dp,參考上一題的區間dp

石子合併(一)

那麼這題也可以從中得到啟發

那麼我第一次的**

#include#include#include#include#includeusing namespace std;

const int inf=0x3f3f3f3f;

char s[105];

int dp[105][105];

int js(int a,int k,int b)

return 2*ans;

}int main()

{ int t;

scanf("%d",&t);

while(t--)

{scanf("%s",s);

int len=strlen(s);

memset(dp,0,sizeof(dp));

for(int i=0; i然而是個wa

如樣例   [ ( ] [ ) ]  輸出的-2

問題在於 當用  [ ( ]  和[ ) ] 合併時候 成-2了(可以自行模擬一下過程)

有些括號在弄的時候重複計算了,上面的函式計算了兩次,那麼就減多了,出現負數就不足為怪了

為了解決問題,我們查到一對配對括號就把他刪除了

那麼就是這步

if(s[i]=='('&&s[j]==')'||s[i]=='['&&s[j]==']')

dp[i][j]=dp[i+1][j-1];

如果發現配對括號就減去(即兩邊都向中間縮減)

於是就有下面的**

#include#include#include#include#includeusing namespace std;

const int inf=0x3f3f3f3f;

char s[105];

int dp[105][105];

int main()

{ int t;

scanf("%d",&t);

while(t--)

{scanf("%s",s);

int len=strlen(s);

memset(dp,0,sizeof(dp));

for(int i=0; i

NYOJ 括號匹配(二)

include include const int maxn 10001 char s maxn int dp maxn max void lics max 0 for int i 0 i時間限制 1000 ms 記憶體限制 65535 kb 難度 6描述 給你乙個字串,裡面只包含 四種符號,請問你...

NYOJ15 括號匹配(二)

題目分析 最開始我想的是用棧來做,結果發現每次求最小不是那麼容易的事情。再說這道題劃分在動態規劃之中也是有它的原因的。這裡用乙個陣列dp來記錄從字串的位置i到位置j至少需要新增的括號數。當然如果i到j只包含乙個字元,那dp i j 一定為1 否則就賦值成乙個比較大的數。如果第i個字元和第j個字元匹配...

nyoj15括號匹配(二)

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