热门标签 | HotTags
当前位置:  开发笔记 > 程序员 > 正文

这是二叉搜索树吗?

一棵二叉搜索树可被递归地定义为具有下列性质的二叉树:对于任一结点,其左子树中所有结点的键值小于该结点的键值;其右子树中所有结点的键值大于等于该结点的键值;其左右子树都是二叉

一棵二叉搜索树可被递归地定义为具有下列性质的二叉树:对于任一结点,

  • 其左子树中所有结点的键值小于该结点的键值;
  • 其右子树中所有结点的键值大于等于该结点的键值;
  • 其左右子树都是二叉搜索树。

所谓二叉搜索树的“镜像”,即将所有结点的左右子树对换位置后所得到的树。

给定一个整数键值序列,现请你编写程序,判断这是否是对一棵二叉搜索树或其镜像进行前序遍历的结果。

输入格式:

输入的第一行给出正整数N(<=1000)。随后一行给出N个整数键值,其间以空格分隔。

输出格式:

如果输入序列是对一棵二叉搜索树或其镜像进行前序遍历的结果,则首先在一行中输出“YES”,然后在下一行输出该树后序遍历的结果。数字间有1个空格,一行的首尾不得有多余空格。若答案是否,则输出“NO”。

输入样例1:
7
8 6 5 7 10 8 11
输出样例1:
YES
5 7 6 8 11 10 8
输入样例2:
7
8 10 11 8 6 7 5
输出样例2:
YES
11 8 10 7 5 6 8
输入样例3:
7
8 6 8 5 10 9 11
输出样例3:
NO

#include   
#include   
using namespace std;  
int a[1003], n, k = 0, b[1003];   
int check1(int l, int r)  
{  
    if(l > r)  
        return 1;  
    int root = a[l];//把根节点拿出来   
    int i, j;  
    for(i = l + 1 ; i <= r && a[i]  r)  
        return 1;  
    int root = a[l];  
    int i, j;  
    for(i = l + 1 ; i <= r && a[i] >= root; i++);  
    for(j = i ; j <= r ; j++)  
    {  
        if(a[j] >= root)  
            return 0;  
    }  
    if(check2(l + 1, i - 1) == 0)  
        return 0;  
    if(check2(i, r) == 0)  
        return 0;  
    b[k++] = a[l];  
    return 1;  
}  
int main()  
{  
    int i;  
    scanf("%d", &n);  
    for(i = 1 ; i <= n ; i++)  
        scanf("%d", &a[i]);  
    if(n == 1)  
    {  
        printf("YES\n%d\n", a[1]);  
        return 0;  
    }  
    if(a[1] > a[2])  
    {  
        if(check1(1, n))  
        {  
            printf("YES\n");  
            for(i = 0 ; i  
 

代码链接点击打开链接

题目链接点击打开链接

说实话此题的代码引起了我的深思,,

后面的代码可以将前序遍历变成中序遍历

#include   
#include   
using namespace std;  
int a[1003], n, k = 0, b[1003];   
int check1(int l, int r)  
{  
    if(l > r)  
        return 1;  
    int root = a[l];//把根节点拿出来   
    int i, j;  
    for(i = l + 1 ; i <= r && a[i]  r)  
        return 1;  
    int root = a[l];  
    int i, j;  
    for(i = l + 1 ; i <= r && a[i] >= root; i++);  
    for(j = i ; j <= r ; j++)  
    {  
        if(a[j] >= root)  
            return 0;  
    }  
    if(check2(l + 1, i - 1) == 0)  
        return 0;  
		 b[k++] = a[l]; /////////// (重要位置)递归的重要 
    if(check2(i, r) == 0)  
        return 0;  
   
    return 1;  
}  
int main()  
{  
    int i;  
    scanf("%d", &n);  
    for(i = 1 ; i <= n ; i++)  
        scanf("%d", &a[i]);  
    if(n == 1)  
    {  
        printf("YES\n%d\n", a[1]);  
        return 0;  
    }  
    if(a[1] > a[2])  
    {  
        if(check1(1, n))  
        {  
            printf("YES\n");  
            for(i = 0 ; i 代码链接 
 点击打开链接 

推荐阅读
  • 技术分享:从动态网站提取站点密钥的解决方案
    本文探讨了如何从动态网站中提取站点密钥,特别是针对验证码(reCAPTCHA)的处理方法。通过结合Selenium和requests库,提供了详细的代码示例和优化建议。 ... [详细]
  • 本文详细介绍了如何解决Uploadify插件在Internet Explorer(IE)9和10版本中遇到的点击失效及JQuery运行时错误问题。通过修改相关JavaScript代码,确保上传功能在不同浏览器环境中的一致性和稳定性。 ... [详细]
  • 360SRC安全应急响应:从漏洞提交到修复的全过程
    本文详细介绍了360SRC平台处理一起关键安全事件的过程,涵盖从漏洞提交、验证、排查到最终修复的各个环节。通过这一案例,展示了360在安全应急响应方面的专业能力和严谨态度。 ... [详细]
  • 本章将深入探讨移动 UI 设计的核心原则,帮助开发者构建简洁、高效且用户友好的界面。通过学习设计规则和用户体验优化技巧,您将能够创建出既美观又实用的移动应用。 ... [详细]
  • 如何在PHPCMS V9中实现多站点功能并配置独立域名与动态URL
    本文介绍如何在PHPCMS V9中创建和管理多个站点,包括配置独立域名、设置动态URL,并确保各子站能够正常运行。我们将详细讲解从新建站点到最终配置路由的每一步骤。 ... [详细]
  • 本文详细解析了Python中的os和sys模块,介绍了它们的功能、常用方法及其在实际编程中的应用。 ... [详细]
  • 离线环境下的Python及其第三方库安装指南
    在项目开发中,有时会遇到电脑只能连接内网或完全无法联网的情况。本文将详细介绍如何在这种环境下安装Python及其所需的第三方库,确保开发工作的顺利进行。 ... [详细]
  • 掌握远程执行Linux脚本和命令的技巧
    本文将详细介绍如何利用Python的Paramiko库实现远程执行Linux脚本和命令,帮助读者快速掌握这一实用技能。通过具体的示例和详尽的解释,让初学者也能轻松上手。 ... [详细]
  • 本文将详细介绍在Windows 7环境下,检查U盘启动盘是否制作成功的多种方法,包括通过BIOS设置和使用模拟启动工具。 ... [详细]
  • 深入理解 H5C3 和 JavaScript 核心问题
    本文详细探讨了 H5C3 和 JavaScript 中的一些核心编程问题,通过实例解析和代码示例,帮助开发者更好地理解和应用这些技术。 ... [详细]
  • 利用存储过程构建年度日历表的详细指南
    本文将介绍如何使用SQL存储过程创建一个完整的年度日历表。通过实例演示,帮助读者掌握存储过程的应用技巧,并提供详细的代码解析和执行步骤。 ... [详细]
  • 本文详细介绍了macOS系统的核心组件,包括如何管理其安全特性——系统完整性保护(SIP),并探讨了不同版本的更新亮点。对于使用macOS系统的用户来说,了解这些信息有助于更好地管理和优化系统性能。 ... [详细]
  • 使用Vultr云服务器和Namesilo域名搭建个人网站
    本文详细介绍了如何通过Vultr云服务器和Namesilo域名搭建一个功能齐全的个人网站,包括购买、配置服务器以及绑定域名的具体步骤。文章还提供了详细的命令行操作指南,帮助读者顺利完成建站过程。 ... [详细]
  • 近期遇到电脑网络不稳定和游戏时频繁重启的问题,寻求专业建议。网络环境为ADSL调制解调器通过路由器共享给两台电脑使用,怀疑存在ARP攻击或硬件配置问题。希望获得详细的故障排查和解决方案。 ... [详细]
  • Hadoop入门与核心组件详解
    本文详细介绍了Hadoop的基础知识及其核心组件,包括HDFS、MapReduce和YARN。通过本文,读者可以全面了解Hadoop的生态系统及应用场景。 ... [详细]
author-avatar
UIUI张南南
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有