時間限制:3000 ms | 記憶體限制:65535 kb
難度:3
描述現在,有一行括號序列,請你檢查這行括號是否配對。
輸入第一行輸入乙個數n(0輸出
每組輸入資料的輸出佔一行,如果該字串中所含的括號是配對的,則輸出yes,如果不配對則輸出no
樣例輸入
3樣例輸出[(])
(])([()])
nonoyes
1 #include2 #include思想:在表示式中,相同型別的括號(包括:()、、{})是成對出現的,並且當括號在表示式中巢狀時,不允許出現交叉現象。3using
namespace
std;45
char stack[10001];6
char s[10001];7
intmain()831
}32if(top==1
)33 cout<
yes\n";
34else
35 cout<
no\n";
36}37return0;
38 }
檢驗括號匹配的方法,就是對給定的字串依次檢驗:若是左括號,入棧;若是右括號,出棧乙個左括號判斷是否與之匹配;是其他字元,不檢驗。檢驗到字串尾,還要檢查棧是否為空。只有棧空,整個字串才是括號匹配的。
ac結果:
執行結果:
括號配對問題
原文 1.括號匹配的四種可能性 左右括號配對次序不正確 右括號多於左括號 左括號多於右括號 左右括號匹配正確 2.演算法思想 1.順序掃瞄算數表示式 表現為乙個字串 當遇到三種型別的左括號時候讓該括號進棧 2.當掃瞄到某一種型別的右括號時,比較當前棧頂元素是否與之匹配,若匹配,退棧繼續判斷 3.若當...
括號配對問題
描述 現在,有一行括號序列,請你檢查這行括號是否配對。輸入 第一行輸入乙個數n 0 n 100 表示有n組測試資料。後面的n行輸入多組輸入資料,每組輸入資料都是乙個字串s s的長度小於10000,且s不是空串 測試資料組數少於5組。資料保證s中只含有 四種字元 輸出 每組輸入資料的輸出佔一行,如果該...
括號配對問題
時間限制 3000 ms 記憶體限制 65535 kb 難度 3 描述 現在,有一行括號序列,請你檢查這行括號是否配對。輸入第一行輸入乙個數n 0輸出 每組輸入資料的輸出佔一行,如果該字串中所含的括號是配對的,則輸出yes,如果不配對則輸出no 樣例輸入 3 樣例輸出 no noyes 如下 inc...