【數據結構】檢查元素出棧的合法性

這個問題是什麼意思呢?

其實很簡單,題目的意思就是想檢查一個一個序列是否爲另一個序列的合法出棧序列?

若1 2 3 4 5爲入棧序列,則該序列的合法出棧序列爲:5 4 3 2 1     

4 3 2 1  5   3 2 1 4 5   等。。。。


現在要寫一個程序判斷該出棧序列是否正確,我們的思想就是,創建兩個數組(一個存入棧序列,一個存出棧序列),一個棧。


#include <iostream>
using namespace std;

#include <stack>

int IsMatch(int * arr1,int* arr2, int size1,int size2)
{
     if(size1 != size2)
    {
          return -1;
    }
     int* p1 = arr1;
     int* p2 = arr2;
    
    stack< int> s1;
    
     while(size1--)
    {
          if(s1.empty() == true )//若棧爲空,則必須入棧
         {
              if(*p1 == *p2)
             {
                 p1++;
                 p2++;
                 size2--;
                  if(size1==0&&size2==0)
                 {
                       return 1;
                 }
             }
              else
             {
                 s1.push (*p1);
                 p1++;
             }
         }
          else
         {
              if(*p1 == *p2)
             {
                 p1++;
                 p2++;
                 size2--;
             }
              else
             {
                 s1.push (*p1);
                 p1++;
             }
         }
    }
     while(!s1.empty ())
    {
          if(s1.top () == *p2)
         {
             s1.pop ();
             p2++;
             size2--;
         }
          else
         {
              return -1;
         }
    }

     if(s1.empty ()==true )
          return 1;

     else
          return -1;
}
void Test()
{
     int arr1[] ={1,2,3,4,5};
     int arr2[] ={5,4,3,2,1};
     int ret = IsMatch(arr1,arr2,5,5);
    cout<<ret<<endl;
}

int main()
{
    Test();
     return 0;
}







4 3 2 1  5   3 2 1 4 5   等。。。。


現在要寫一個程序判斷該出棧序列是否正確,我們的思想就是,創建兩個數組(一個存入棧序列,一個存出棧序列),一個棧。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章