溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

給定入棧順序,判斷出棧順序是否合法

發布時間:2020-07-01 14:53:16 來源:網絡 閱讀:3470 作者:duanjiatao 欄目:編程語言

題目描述:給定一個入棧序列,給定一個出棧序列,判斷該出棧序列是否合法。


分析:假如入棧序列為1 2 3 4 5,判斷4 5 3 2 1 是否是合法的出棧順序。


兩個序列均以數組的形式給出


從兩個數組的第一個元素開始,如果棧為空,或者,棧頂元素不等于當前出棧數組當前下標對應的元素時,將當前入棧數組中下標所指向的元素進行壓棧


初始狀態如下:

給定入棧順序,判斷出棧順序是否合法

步驟1:把 1 進行壓棧,并將下標后移,如下圖所示,

給定入棧順序,判斷出棧順序是否合法

步驟2:依次進行判斷并壓棧,當4進棧后,此時棧頂元素等于出棧數組下標所指向的元素,將4出棧,如下圖所示


給定入棧順序,判斷出棧順序是否合法

步驟3:將 4 出棧,并將出棧數組的下標后移,繼續判斷棧頂元素是否為當前出棧數組下標對應的元素,是,則出棧,否則繼續往后執行

給定入棧順序,判斷出棧順序是否合法

步驟4:重復上述步驟,直到入棧數組中的下標走到盡頭給定入棧順序,判斷出棧順序是否合法

當最后一個元素入棧后,此時只需循環判斷棧頂元素是否與出棧數組當前下標對應的元素相等,如果該序列合法,則棧中的元素最終都會出棧,不合法則棧永遠不為空

給定入棧順序,判斷出棧順序是否合法

此時,棧為空,則該序列合法。


代碼如下:

#include<iostream>
#include<stack>
#include<cassert>
using namespace std;


template<class T>
bool IsSequenceVaild(const T* inSequence, const T* outSequence, size_t n)
{
	assert(inSequence && outSequence);

	stack<T> sc;
	int j = 0;  //用來記錄出棧數組當前元素的下標
	for (int i = 0; i < n; ++i)
	{
		sc.push(inSequence[i]);

		while (!sc.empty() && sc.top() == outSequence[j])
		{
			sc.pop();
			++j;
		}
	}

	return (sc.size() == 0) ? true : false;
}


void Test1()
{
	int in[5] = { 1, 2, 3, 4, 5 };
	int out1[5] = { 1, 2, 3, 4, 5 };
	int out2[5] = { 4, 5, 3, 2, 1 };
	int out3[5] = { 3, 5, 4, 2, 1 };
	int out4[5] = { 3, 5, 4, 2, 1 };

	int out[5] = { 4, 5, 3, 1, 2 };

	cout << IsSequenceVaild<int>(in, out1, 5) << endl;
	cout << IsSequenceVaild<int>(in, out2, 5) << endl;
	cout << IsSequenceVaild<int>(in, out3, 5) << endl;
}

void main()
{
	Test1();

	system("pause");
}


向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女