這個問題是什麼意思呢?
其實很簡單,題目的意思就是想檢查一個一個序列是否爲另一個序列的合法出棧序列?
若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 等。。。。
現在要寫一個程序判斷該出棧序列是否正確,我們的思想就是,創建兩個數組(一個存入棧序列,一個存出棧序列),一個棧。