亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

括號匹配有問題

#include<stdlib.h>

#include"MyStack.h"


int main()

{

//括號存放棧

MyStack<char> *p = new MyStack<char>(30);

//括號急需匹配棧

MyStack<char> *pNeed = new MyStack<char>(30);

char str[] = "[()]";

char need = 0;

for (int i = 0; i < strlen(str);i++){

if (str[i] != need){

cout << "第" << i+1 << "次入第一個棧:";

p->push(str[i]);

cout << str[i] << endl; ??

switch (str[i]){

case'[':

if (need != 0){

cout << "第" << i + 1 << "次入另一個棧:";

pNeed->push(need);

cout << need<<endl;

}

need = ']';

break;

case'(':

if (need != 0){

cout << "第" << i + 1 << "次入另一個棧:";

pNeed->push(need);

cout << need << endl;;

}

need = ')';

break;

default:

cout << "字符串不匹配" << endl;

system("pause");

return 0;

}

}

else{

char elem=0;

p->pop(elem);

cout << "elem:" << elem<<" ?";

if (!pNeed->pop(need)){

cout << "need:" << need << endl;

need = 0;

}

}

}

if (p->EmptyStack()){

cout << "字符串括號匹配" << endl;

}

else{

cout << "字符串括號不匹配" << endl;

}



delete p;

p = NULL;

delete pNeed;

p = NULL;

system("pause");

return 0;

}

從運行結果可以看出: ‘)’ 這個符號根本沒有進入第二個棧 ?,但結果判定正確的標準是第一個??铡?/p>

http://img1.sycdn.imooc.com//58e24e500001c4ed02250236.jpg

正在回答

1 回答

因為你是先入棧再賦值need。第一次循環的時候,need==0,所以直接need = ']',pNeed里有],第二次循環need==),然后滿足條件。

case'[':

if (need != 0){

cout << "第" << i + 1 << "次入另一個棧:";

pNeed->push(need);

cout << need<<endl;

}

need = ']';

break;


0 回復 有任何疑惑可以回復我~

舉報

0/150
提交
取消
數據結構探險—棧篇
  • 參與學習       62770    人
  • 解答問題       105    個

棧,先入后出(FILO),帶領大家體會棧這種數據結構的美妙

進入課程

括號匹配有問題

我要回答 關注問題
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號