题目描述:
开始一个数n,(1<=n<=20) 表示有n个需要判断,n= 0 的时候输入结束。
接下去一行是一个序列,序列长度小于10,包含(0~9)的数字,没有重复数字,根据这个序列可以构造出一颗二叉搜索树。
接下去的n行有n个序列,每个序列格式跟第一个序列一样,请判断这两个序列是否能组成同一颗二叉搜索树。
输入例子:
2
567432
543267
576342
0
输出例子:
YES
NO
#include <stdio.h>
#include <vector>
#include <string>
#include <iostream>
using namespace std;
bool Judge(vector<int> &tree, vector<int> &obj)
{
if (tree.size() == 0 && obj.size() == 0)
{
return true;
}
if (tree.size() != obj.size() || tree[0] != obj[0])
{
return false;
}
vector<int> tree_left;
vector<int> tree_right;
vector<int> obj_left;
vector<int> obj_right;
for (int i = 1; i < tree.size(); i+&#