這個問題是什麼意思呢?
其實很簡單,題目的意思就是想檢查乙個乙個序列是否為另乙個序列的合法出棧序列?
若1 2 3 4 5為入棧序列,則該序列的合法出棧序列為:5 4 3 2 1
4 3 2 1 5 3 2 1 4 5 等。。。。
現在要寫乙個程式判斷該出棧序列是否正確,我們的思想就是,建立兩個陣列(乙個存入棧序列,乙個存出棧序列),乙個棧。
#include using namespace std;
#include int ismatch(int * arr1,int* arr2, int size1,int size2)
int* p1 = arr1;
int* p2 = arr2;
stack< int> s1;
while(size1--)
}else
}else
else}}
while(!s1.empty ())
else
}if(s1.empty ()==true )
return 1;
else
return -1;
}void test()
; int arr2 =;
int ret = ismatch(arr1,arr2,5,5);
cout<
4 3 2 1 5 3 2 1 4 5 等。。。。
現在要寫乙個程式判斷該出棧序列是否正確,我們的思想就是,建立兩個陣列(乙個存入棧序列,乙個存出棧序列),乙個棧。
元素出棧 入棧順序的合法性 資料結構
元素出棧 入棧順序的合法性。如入棧的序列 1,2,3,4,5 出棧序列為 4,5,3,2,1 test.c int teststackinandoutvalid int in,int insize,int out,int outsize 棧為空,棧頂元素與出棧次序索引標記位置元素值不相等,入棧 入棧...
出棧合法性
題目描述 已知自然數1,2,n 1 n 100 依次入棧,請問序列c1,c2,cn是否為合法的出棧序列。輸入包含多組測試資料。每組測試資料的第一行為整數n 1 n 100 當n 0時,輸入結束。第二行為n個正整數,以空格隔開,為出棧序列。對於每組輸入,輸出結果為一行字串。如給出的序列是合法的出棧序列...
出棧的合法性
1788 出棧合法性 時間限制 1 sec 記憶體限制 32 mb 提交 153 解決 60 提交 狀態 討論版 題目描述 已知自然數1,2,n 1 n 100 依次入棧,請問序列c1,c2,cn是否為合法的出棧序列。輸入 輸入包含多組測試資料。每組測試資料的第一行為整數n 1 n 100 當n 0...