找回密碼 或 安全提問
 註冊
|註冊|登錄

伊莉討論區

搜索
尊貴會員無限使用任何功能尊貴會員無限下載附件安全提問(回答) 和 永久尊貴會員 事宜
fc2七龍珠一拳超人fc2進擊的巨母乳高中
命中注定sone 162dungeon ボクが魔gdtm 108金庸群俠pure×ho

休閒聊天興趣交流學術文化旅遊交流飲食交流家庭事務PC GAMETV GAME
熱門線上其他線上感情感性寵物交流家族門派動漫交流貼圖分享BL/GL
音樂世界影視娛樂女性頻道潮流資訊BT下載區GB下載區下載分享短片
電腦資訊數碼產品手機交流交易廣場網站事務長篇小說體育運動時事經濟
上班一族博彩娛樂

2024年10月新番『香格

[繁]我的妻子不具感情

[繁]狼與辛香料 Merch

[繁]不時輕聲地以俄語

[繁]靠廢柴技能【狀態

[簡]義妹生活12- (完)
C & C++ 語言C# 語言Visual Basic 語言PHP 語言JAVA 語言
查看: 4511|回復: 1
打印上一主題下一主題

[作業]實作堆疊 (Stack) 及判斷括號合法性[複製鏈接]

Rank: 2Rank: 2

帖子
1457
積分
795 點
潛水值
15988 米
跳轉到指定樓層
樓主
發表於 2010-11-2 04:01 PM|只看該作者|倒序瀏覽
回覆中加入附件並不會使你增加積分,請使用主題方式發佈附件。
題目:請撰寫堆疊之結構,其結構成員如下所示:
struct MyStack
{
int Top;
char a[MAX];
bool IsEmpty();
bool IsFull();
void Push(char);
char Pop();
};
題意說明:讀入資料檔(1102.txt),檔案中是一串由( ) [ ] { }所組成的字串,請利用堆疊 (Stacks) 的原理來撰寫一個程式,判斷字串中的括號是否合法,一個( ) [ ] { }必須對稱存在,而且對應的括號之間不能插入單獨的括號,
...
瀏覽完整內容,請先 註冊登入會員
分享分享0收藏收藏0支持支持0
若有安裝色情守門員,可用無界、自由門等軟件瀏覽伊莉。或使用以下網址瀏覽伊莉: http://www.eyny.com:81/index.php

使用道具檢舉

Rank: 3Rank: 3Rank: 3

帖子
722
積分
2721 點
潛水值
16557 米
頭香
發表於 2010-11-2 06:06 PM|只看該作者
關鍵的 stack 行為與合法判斷流程如下
  1. #define MAX_SIZE 50

  2. class CMyStack{
  3. private:
  4.     int m_iTop;
  5.     char m_Element[MAX_SIZE];
  6. public:
  7.     CMyStack(){ m_iTop = 0; }
  8.     bool isEmpty(){ return m_iTop == 0; }
  9.     bool isFull(){ return m_iTop >= MAX_SIZE; }
  10.     void push( char e ){ m_Element[m_iTop++] = e; }
  11.     char pop(){ return m_iTop == 0 ? 0 : m_Element[--m_iTop]; }
  12.     void clear(){ m_iTop = 0; }
  13. };

  14. int main(){
  15.     char* input[4] = { "{[()]}", "((([]))", "({[()][]})", "[]{[()]{}" };
  16.     CMyStack stack;
  17.     for( int i=0; i<4; ++i ){
  18.         stack.clear();
  19.         bool isCorrect = true;
  20.         for( char* pSymbol=input[i]; *pSymbol&&isCorrect; ++pSymbol ){
  21.             switch( *pSymbol ){
  22.             case '{': case '[': case '(':
  23.                 stack.push( *pSymbol );
  24.                 break;
  25.             case '}':
  26.                 if( stack.isEmpty() || stack.pop() != '{' )
  27.                     isCorrect = false;
  28.                 break;
  29.             case ']':
  30.                 if( stack.isEmpty() || stack.pop() != '[' )
  31.                     isCorrect = false;
  32.                 break;
  33.             case ')':
  34.                 if( stack.isEmpty() || stack.pop() != '(' )
  35.                     isCorrect = false;
  36.                 break;
  37.             default:
  38.                 isCorrect = false;
  39.             }
  40.         }
  41.         cout << input[i] << ( isCorrect && stack.isEmpty() ? ": CORRECT" : ": ERROR" ) << endl;
  42.     }
  43.     system( "pause" );
  44.     return 0;
  45. }
複製代碼
...
瀏覽完整內容,請先 註冊登入會員
若新密碼無法使用,可能是數據未更新。請使用舊密碼看看。

使用道具檢舉

您需要登錄後才可以回帖 登錄 | 註冊

Powered by Discuz!

© Comsenz Inc.

重要聲明:本討論區是以即時上載留言的方式運作,對所有留言的真實性、完整性及立場等,不負任何法律責任。而一切留言之言論只代表留言者個人意見,並非本網站之立場,用戶不應信賴內容,並應自行判斷內容之真實性。於有關情形下,用戶應尋求專業意見(如涉及醫療、法律或投資等問題)。 由於本討論區受到「即時上載留言」運作方式所規限,故不能完全監察所有留言,若讀者發現有留言出現問題,請聯絡我們。有權刪除任何留言及拒絕任何人士上載留言,同時亦有不刪除留言的權利。切勿上傳和撰寫 侵犯版權(未經授權)、粗言穢語、誹謗、渲染色情暴力或人身攻擊的言論,敬請自律。本網站保留一切法律權利。
回頂部