第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

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

括號匹配有問題

#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;

}

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

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

正在回答

1 回答

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

case'[':

if (need != 0){

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

pNeed->push(need);

cout << need<<endl;

}

need = ']';

break;


0 回復(fù) 有任何疑惑可以回復(fù)我~

舉報

0/150
提交
取消
數(shù)據(jù)結(jié)構(gòu)探險—棧篇
  • 參與學(xué)習(xí)       62767    人
  • 解答問題       105    個

棧,先入后出(FILO),帶領(lǐng)大家體會棧這種數(shù)據(jù)結(jié)構(gòu)的美妙

進入課程

括號匹配有問題

我要回答 關(guān)注問題
微信客服

購課補貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學(xué)習(xí)伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號