hdu 3791 二叉搜索树

来源:互联网 发布:双拼域名交易 编辑:程序博客网 时间:2024/06/14 03:47
做这道题首先知道二叉树搜索树的定义是关键! ! !
  
注意: 二叉树和二叉搜索树(BST)的概念是不同的,二叉搜索树是一种特殊的二叉树。它符合规律:所有节点的左孩子节点的值小于它根节点的值,右孩子节点的值大于根节点的值。就是小数放左边,大数放右边,来构成一棵二叉树。(还不明白的点击上面有下划线的深色链接)
  一开始没有搞明白两者的区别,以为二叉搜索树就是二叉树,这让我在构造二叉树的时候产生了疑惑,因为根据数据结构书上的描述,二叉树可以根据前序、中序、后序序列构造,这样产生的结果就是不唯一的。最后还是查找了一下二叉搜索树的概念才明白过来。根据它的规则就可以根据一个序列构成一个唯一的二叉搜索树了!而同一个二叉搜索树却可以有不同的序列来描述。这就产生了这道题的题意:给你两个不同的序列判断是否能构造出同一个二叉搜索树。
  思路:那么我们就可以根据二叉搜索树的生成规则先将一开始给你的序列生成一个二叉搜索树用tree[]存储起来,然后输入n个序列,每一个序列都生成一个二叉

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

#include<stdio.h>#include<string.h>int main(){    char s[11];    int n;    while(~scanf("%d",&n))    {        if(n==0)break;        scanf("%s",s);        int tree[1025];        memset(tree,-1,sizeof(tree));        for(int i=0;s[i];i++)  //构造二叉搜索树        {            int num=s[i]-'0';            int j=1;            while(tree[j]!=-1)            {                if(num<=tree[j])                    j=j*2;                else                    j=j*2+1;            }            tree[j]=num;        }        while(n--)        {            char str[11];            scanf("%s",str);            int tree1[1025];            memset(tree1,-1,sizeof(tree1));            for(int i=0;str[i];i++)//构造比较二叉搜索树            {                int num=str[i]-'0';                int j=1;                while(tree1[j]!=-1)                {                    if(num<=tree1[j])                        j=j*2;                    else                        j=j*2+1;                }                tree1[j]=num;            }            int i;            for(i=0;i<=1024&&tree[i]==tree1[i];i++);//比较是否相等            if(i>1024)                printf("YES\n");            else                printf("NO\n");        }    }    return 0;}

搜索树建立一个临时数组tree2[]存储,比较两个数组是否相同,相同输出“YES”,不同输出“NO”。
原创粉丝点击