HDU3791 二叉搜索树【二叉搜索树】

二叉搜索树
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 9645 Accepted Submission(s): 4265

Problem Description
判断两序列是否为同一二叉搜索树序列

Input
开始一个数n,(1<=n<=20) 表示有n个需要判断,n= 0 的时候输入结束。
接下去一行是一个序列,序列长度小于10,包含(0~9)的数字,没有重复数字,根据这个序列可以构造出一颗二叉搜索树。
接下去的n行有n个序列,每个序列格式跟第一个序列一样,请判断这两个序列是否能组成同一颗二叉搜索树。

Output
如果序列相同则输出YES,否则输出NO

Sample Input

2
567432
543267
576342
0

Sample Output

YES
NO

Source
浙大计算机研究生复试上机考试-2010年

问题链接:HDU3791 二叉搜索树
问题简述:(略)
问题分析:简单的二叉搜索树问题,不解释。
程序说明:(略)
参考链接:(略)
题记:(略)

AC的C++语言程序如下:

/* HDU3791 二叉搜索树 */

#include 

using namespace std;

const int N = 10 + 1, M = 3000;
char s[N];
int tree1[M], tree2[M];

void insert(char ch, int* tree)
{
    int cnt = 1;
    int x = ch - '0';
    while (tree[cnt] != -1)
        if (tree[cnt] < x) cnt = 2 * cnt + 1;
        else cnt = 2 * cnt;
    tree[cnt] = x;
}

void build(char* s, int* tree)
{
    tree[1] = s[0] - '0';
    for (int i = 1; s[i]; i++)
        insert(s[i], tree);
}

int main()
{
    int n;
    while(~scanf("%d", &n) && n) {
        scanf("%s", s);
        memset(tree1, -1, sizeof(tree1));
        build(s, tree1);

        while(n--) {
            scanf("%s", s);
            memset(tree2, -1, sizeof(tree2));
            build(s, tree2);

            bool flag = false;
            for(int i = 0; i < M; i++)
                if(tree1[i] != tree2[i]) {flag = true; break;}

            printf("%s\n", flag ? "NO" : "YES");
        }
    }

    return 0;
}

你可能感兴趣的:(#,ICPC-树,#,ICPC-数据结构,#,ICPC-HDU,HDU3791,二叉搜索树)