luogu1155 雙棧排序

2021-08-19 17:51:37 字數 997 閱讀 4638

題目描述

tom最近在研究乙個有趣的排序問題。如圖所示,通過2個棧s1和s2,tom希望借助以下4種操作實現將輸入序列公升序排序。

操作a如果輸入序列不為空,將第乙個元素壓入棧s1

操作b如果棧s1不為空,將s1棧頂元素彈出至輸出序列

操作c如果輸入序列不為空,將第乙個元素壓入棧s2

操作d如果棧s2不為空,將s2棧頂元素彈出至輸出序列

如果乙個1~n的排列p可以通過一系列操作使得輸出序列為1,2,…,(n-1),n,tom就稱p是乙個「可雙棧排序排列」。例如(1,3,2,4)就是乙個「可雙棧排序序列」,而(2,3,4,1)不是。下圖描述了乙個將(1,3,2,4)排序的操作序列:

#include

#include

#include

#define inf 0x7f7f7f7f

#define n 1100

using

namespace

std;

inline

char gc()

return *s++;

}inline

int read()

return x;

}int color[n];int h[n],s1[n],s2[n],a[n],min1[n],num,n;

struct nodedata[n*n*2];

inline

void insert1(int x,int y)

bool dfs(int x,int colour)

return

true;

}int main()

int top1=0,top2=0,now=1;

for (int i=1;i<=n;++i)else

while (s1[top1]==now||s2[top2]==now)

if (s2[top2]==now)++now;}}

return

0;}

P1155 雙棧排序

tom最近在研究乙個有趣的排序問題。如圖所示,通過2個棧s1和s2,tom希望借助以下4種操作實現將輸入序列公升序排序。操作a如果輸入序列不為空,將第乙個元素壓入棧s1 操作b如果棧s1不為空,將s1棧頂元素彈出至輸出序列 操作c如果輸入序列不為空,將第乙個元素壓入棧s2 操作d如果棧s2不為空,將...

P1155 雙棧排序

tom最近在研究乙個有趣的排序問題。如圖所示,通過2個棧s1 和s2 tom希望借助以下4種操作實現將輸入序列公升序排序。操作a如果輸入序列不為空,將第乙個元素壓入棧s1 操作b如果棧s1 不為空,將s1 棧頂元素彈出至輸出序列 操作c如果輸入序列不為空,將第乙個元素壓入棧s2 操作d如果棧s2 不...

P1155 雙棧排序

miku 規律 假如只有乙個棧,那麼如果原序列存在三個數x v y v x v z 那麼就不可能排序成功,但是這裡有兩個棧,那麼就應該把原序列分成兩部分 兩部分?二分圖。把不能在一起的點連邊,進行二分圖染色。如果成功,就意味著存在 兩個棧的成員搞定了 反之不存在 include include in...