0

スタックの使用方法と、作成中のコードでスタックを使用する理由に少し固執しています。割り当ては、ユーザー入力が整形式かどうかをチェックするプログラムを書くことを示しています。これは、ユーザーが選択できる 3 つの異なる選択肢を持つ単純なプログラムです。1. 基本ブラケット () 2. 標準ブラケット ()[]{} および 3. ユーザー定義ブラケット。メインプログラムが行うことになっている唯一のことは、ユーザーの入力が整形式かどうかをチェックし、そのメッセージだけを画面に表示することです。

main.cpp と共に使用している StackLS.cpp と Stack.h ファイルがあります。それぞれの下にサンプルコードを貼り付けておきます。

StackLS.h

typedef int elemType; // flexible data type

class StackLS
{
 private:
// inner class node

class Node
{
public:
    elemType data; // data portion
    Node *next; // link to the seccessor
}; // end Node

// data members
Node *topItem; // pointer to the top element of this stack

// utilities

       public:
// constructors
StackLS(void); // default constructor
StackLS(const StackLS& aStack); // copy constructor

// observers
bool isEmpty(void) const;
// returns true if this stack is empty
//         false otherwise

bool isFull(void) const;
// returns true if this stack is full
//         false otherwise

elemType top(void) const;
// precondition: this stack is not empty
// returns top element in this stack

// transformers
void push(const elemType& item);
// precondition: this stack is not full
// adds item to this stack

void pop(void);
// removes top element from this stack if exist
// remains empty otherwise

void makeEmpty(void);
// makes this stack empty

// destructor
~StackLS(void);
}; // end StackLS

StackLS.cpp

     // constructors
      StackLS::StackLS(void)
     // default constructor
     {
topItem = 0;
      } // end default constructor

        StackLS::StackLS(const StackLS& aStack)
     // copy constructor
       {
       } // end copy constructor

      // observers
       bool StackLS::isEmpty(void) const
       // returns true if this stack is empty
       //         false otherwise
        {
  return topItem == 0;
         } // end isEmpty

         bool StackLS::isFull(void) const
       // returns true if this stack is full
       //         false otherwise
        {
return false;
         } // end isFull

         elemType StackLS::top(void) const
      // precondition: this stack is not empty
       // returns top element in this stack
        {
// return (*topItem).data;
return topItem->data;
      } // end top

       // transformers
        void StackLS::push(const elemType& item)
       // precondition: this stack is not full
            // adds item to this stack
           {
Node *newNode = new Node;
newNode->data = item;
newNode->next = topItem;
topItem = newNode;
       } // end push

       void StackLS::pop(void)
       // removes top element from this stack if exist
       // remains empty otherwise
       {
if (topItem != 0)
{
    Node *temp = topItem;
    topItem = topItem->next;
    delete temp;
}
      } // end pop

      void StackLS::makeEmpty(void)
       // makes this stack empty
        {
    while (topItem != 0)
{
    Node *temp = topItem;
    topItem = topItem->next;
    delete temp;
    }
        } // end makeEmpty

         // destructor
          StackLS::~StackLS(void)
         {
//while (!isEmpty())
//  pop();
while (topItem != 0)
{
    Node *temp = topItem;
    topItem = topItem->next;
    delete temp;
}
      } // end destructor

これが私がこれまでに持っているmain.cppです。 main.cpp

      #include <iostream>
      #include <string>
      #include "StackLS.h"
      using namespace std;

         do {

      int main()
       {
char answer;
char n;
StackLS stack;

cout << " ********** MENU ********** " << endl;
cout << " 1. Basic Brackets () " << endl;
cout << " 2. Standard Brackets ()[]{} " << endl;
cout << " 3. User-Defined brackets " << endl;
cout << " Please enter your choice: " << endl;

switch (choice){
case 1: 
    cout << "Current Setting: () " << endl;
    cout << "Enter your expression followed by a ; : " << endl;
    do {

    cin >> answer;
        while (answer != ;)
    }


          } // end main

        }
while (choice != 'n' || 'N') 

繰り返しますが、このプログラム (main.cpp) で示したスタックをどのように使用するのか疑問に思っています。なぜスタックを使用するのか、その理由について少し混乱しています。どんな助けでも大歓迎です。ありがとう。main.cpp は正しくないかもしれませんが、ここでも学習しているので、詳細を学ぶためにここにいます。ありがとう

4

1 に答える 1

1

開き中かっこが表示されたら、それをスタックにプッシュします。閉じ中かっこが表示されたら、それがスタックの一番上にある中かっこの対応するものであることを確認してから、それを取り除きます。入力が完了したら、スタックが空であることを確認します。

于 2012-04-12T02:48:07.230 に答える