SDUTOJ 2482 二叉排序树
来源:互联网 发布:资海网络集团员工待遇 编辑:程序博客网 时间:2024/05/22 12:10
二叉排序树
Time Limit: 1000MS Memory limit: 65536K
题目描述
二叉排序树的定义是:或者是一棵空树,或者是具有下列性质的二叉树: 若它的左子树不空,则左子树上所有结点的值均小于它的根结点的值; 若它的右子树不空,则右子树上所有结点的值均大于它的根结点的值; 它的左、右子树也分别为二叉排序树。 今天我们要判断两序列是否为同一二叉排序树
输入
开始一个数n,(1<=n<=20) 表示有n个需要判断,n= 0 的时候输入结束。
接下去一行是一个序列,序列长度小于10,包含(0~9)的数字,没有重复数字,根据这个序列可以构造出一颗二叉排序树。
接下去的n行有n个序列,每个序列格式跟第一个序列一样,请判断这两个序列是否能组成同一颗二叉排序树。(数据保证不会有空树)
输出
示例输入
21234567899876543214321567890
示例输出
NONO
提示
来源
示例程序
明白二叉树就知道这是什么东西了。。。
中序遍历就不可以.......
示例代码:
#include<iostream>
#include<algorithm>
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<string>
using namespace std;
struct node
{
char data;
struct node *left,*right;
};
int n;
struct node *creat(struct node *&root,char m)
{
if(root == NULL)
{
root = (struct node*)malloc(sizeof(struct node));
root->left = NULL;
root->right = NULL;
root->data = m;
}
else
{
if(m < root->data)
{
creat(root->left,m);
}
else
{
creat(root->right,m);
}
}
}
int s;
char a[10001],b[10000];
void xianxu(struct node *root)
{
if(root!=NULL)
{
a[s++] = root->data;
xianxu(root->left);
xianxu(root->right);
}
}
int main()
{
while(scanf("%d",&n)!=EOF)
{
char m;
char str[10001],str1[11100];
struct node *root = NULL;
scanf("%s",&str);
s = 0;
for(int i=0;str[i]!='\0';i++)
{
creat(root,str[i]);
}
xianxu(root);
a[s] = '\0';
strcpy(b,a);
//printf("b = %s\n",b);
for(int i=0;i<n;i++)
{
s = 0;
scanf("%s",str1);
struct node *pp = NULL;
for(int j=0;str1[j]!='\0';j++)
{
creat(pp,str1[j]);
}
xianxu(pp);
a[s] = '\0';
//printf("a = %s\n",a);
if(strcmp(a,b) == 0)
{
printf("YES\n");
}
else
{
printf("NO\n");
}
}
}
return 0;
}
#include<algorithm>
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<string>
using namespace std;
struct node
{
char data;
struct node *left,*right;
};
int n;
struct node *creat(struct node *&root,char m)
{
if(root == NULL)
{
root = (struct node*)malloc(sizeof(struct node));
root->left = NULL;
root->right = NULL;
root->data = m;
}
else
{
if(m < root->data)
{
creat(root->left,m);
}
else
{
creat(root->right,m);
}
}
}
int s;
char a[10001],b[10000];
void xianxu(struct node *root)
{
if(root!=NULL)
{
a[s++] = root->data;
xianxu(root->left);
xianxu(root->right);
}
}
int main()
{
while(scanf("%d",&n)!=EOF)
{
char m;
char str[10001],str1[11100];
struct node *root = NULL;
scanf("%s",&str);
s = 0;
for(int i=0;str[i]!='\0';i++)
{
creat(root,str[i]);
}
xianxu(root);
a[s] = '\0';
strcpy(b,a);
//printf("b = %s\n",b);
for(int i=0;i<n;i++)
{
s = 0;
scanf("%s",str1);
struct node *pp = NULL;
for(int j=0;str1[j]!='\0';j++)
{
creat(pp,str1[j]);
}
xianxu(pp);
a[s] = '\0';
//printf("a = %s\n",a);
if(strcmp(a,b) == 0)
{
printf("YES\n");
}
else
{
printf("NO\n");
}
}
}
return 0;
}
0 0
- SDUTOJ 2482 二叉排序树
- SDUTOJ 2482 二叉排序树
- 二叉排序树 SDUTOJ 2482
- SDUTOJ 2128 ——二叉排序树
- sdutoj
- SDUTOJ
- SDUToj
- SDUToj
- SDUToj
- [2482]二叉排序树
- 2482二叉排序树
- 2482-二叉排序树
- 2482-二叉排序树
- SDUT 2482 二叉排序树
- SDUT 2482 二叉排序树
- SDUT 2482 二叉排序树
- SDUT 2482 二叉排序树
- SDUT 2482 二叉排序树
- [LeetCode]Interleaving String
- kinetic学习之(三) UART
- mahout中得距离测度
- Python 中的range(),arange()函数
- Pow(x, n)
- SDUTOJ 2482 二叉排序树
- CSS学习笔记三
- 安卓4.0蓝牙开发
- 细探颜色值
- asp.net--站点架构(页脚设计)和配色与样式统一设定
- HDU 4715 Difference Between Primes(数学啊)
- 【BZOJ】【P3252】【攻略】【题解】【贪心+dfs序+线段树】
- PullToRefresh实现下拉刷新和上拉加载
- SDUTOJ 2128 树结构练习——排序二叉树的中序遍历