time limit: 1000ms memory limit: 65536k 有疑問?點這裡^_^
二叉排序樹的定義是:或者是一棵空樹,或者是具有下列性質的二叉樹: 若它的左子樹不空,則左子樹上全部結點的值均小於它的根結點的值; 若它的右子樹不空,則右子樹上全部結點的值均大於它的根結點的值; 它的左、右子樹也分別為二叉排序樹。 今天我們要推斷兩序列是否為同一二叉排序樹
開始乙個數n,(1<=n<=20) 表示有n個須要推斷,n= 0 的時候輸入結束。
接下去一行是乙個序列,序列長度小於10,包括(0~9)的數字,沒有反覆數字,依據這個序列能夠構造出一顆二叉排序樹。
接下去的n行有n個序列。每乙個序列格式跟第乙個序列一樣,請推斷這兩個序列能否組成同一顆二叉排序樹。(資料保證不會有空樹)
2123456789
987654321
432156789
0
nono
#include#include#includeusing namespace std;
char s[11],c[11];
int a[11],b[12],len,num=0,z[11];
struct tree
*root;
tree *creat()
int hhh(tree *root) //前序
}int middle(tree *root) //中序
}tree build(tree *root,int c) //排列樹的建立
else
p=p->l;
}else
else
p=p->r;}}
}}int main()
{ int n;
while(~scanf("%d",&n))
{if(n==0)
break;
root=creat(); //母樹
scanf("%s",s);
len=strlen(s);
for(int i=0; il->data);
middle(root);
int x[11],x1[11];
for(int i=0; idata;
int y[11],y1[11];
for(int i=0; i
SDUT 2482 二叉排序樹
這個題也是比較簡單的,但悲催的我忘了把除錯用的 注釋掉,結果錯了幾遍。sad 操作步驟是這樣的 1 對第1個數字序列進行建樹操作,並儲存先序遍歷的結果。2 對後來要比較的數字序列進行建樹操作,並儲存先序遍歷結果。3 比較兩個結果是否相同。以下是 include include include typ...
SDUT 2482 二叉排序樹
time limit 1000ms memory limit 65536k 二叉排序樹的定義是 或者是一棵空樹,或者是具有下列性質的二叉樹 若它的左子樹不空,則左子樹上所有結點的值均小於它的根結點的值 若它的右子樹不空,則右子樹上所有結點的值均大於它的根結點的值 它的左 右子樹也分別為二叉排序樹。今...
sdut 2482 二叉排序樹
time limit 1000 ms memory limit 65536 kib submit statistic discuss problem description 二叉排序樹的定義是 或者是一棵空樹,或者是具有下列性質的二叉樹 若它的左子樹不空,則左子樹上所有結點的值均小於它的根結點的值 ...