7-31 笛卡尔树(25分)(题目分析+简单算法+详解+思路)

一:题目

7-31 笛卡尔树 (25 分)
笛卡尔树是一种特殊的二叉树,其结点包含两个关键字K1和K2。首先笛卡尔树是关于K1的二叉搜索树,即结点左子树的所有K1值都比该结点的K1值小,右子树则大。其次所有结点的K2关键字满足优先队列(不妨设为最小堆)的顺序要求,即该结点的K2值比其子树中所有结点的K2值小。给定一棵二叉树,请判断该树是否笛卡尔树。

输入格式:
输入首先给出正整数N(≤1000),为树中结点的个数。随后N行,每行给出一个结点的信息,包括:结点的K1值、K2值、左孩子结点编号、右孩子结点编号。设结点从0~(N-1)顺序编号。若某结点不存在孩子结点,则该位置给出−1。

输出格式:
输出YES如果该树是一棵笛卡尔树;否则输出NO。

输入样例1:

6
8 27 5 1
9 40 -1 -1
10 20 0 3
12 21 -1 4
15 22 -1 -1
5 35 -1 -1

输出样例1:
YES
输入样例2:

6
8 27 5 1
9 40 -1 -1
10 20 0 3
12 11 -1 4
15 22 -1 -1
50 35 -1 -1

输出样例2:
NO

二:题目分析+思路

分析题意和示例:
每一行代表这个结点的序号(即第几行为第几个结点)
拿示例一来说:(其实也就是 该结点 该结点的左孩子,该结点的右孩子)
6
(0) 8 27 5 1
(1) 9 40 -1 -1
(2) 10 20 0 3
(3) 12 21 -1 4
(4) 15 22 -1 -1
(5) 5 35 -1 -1

思路: 用 两个map<int,int> 进行 存前两行的数据 其中 第一个int为行号,第二个int为每行的数据,然后单独处理后两行进行建树,建完树后中序输出,然后通过map找到对应的键值是否为升序,这是判读K1的条件是否成立;笛卡尔树的第二个条件是  该树的除叶节点外,其余结点的值都比左右孩子的值大 ,这个既然树已经建好了那就用递归做。补充:其中建树的算法还很炫!代码中也有解释。

三:如果map容器的用法和vector容器的算法不熟悉 下方链接学习下哈

map容器的用法
vector容器的用法

四:上码

/**分析题意和示例:每一行代表这个结点的序号(即第几行为第几个结点)拿示例一来说:(其实也就是 该结点  该结点的左孩子,该结点的右孩子) 6(0)	8 27 5 1(1)	9 40 -1 -1(2)	10 20 0 3(3)	12 21 -1 4(4)	15 22 -1 -1(5)	5 35 -1 -1 思路: 先建树,用 两个map<int,int> 进行 存前两行的数据 其中 第一个int为 行号第二个int为每行的数据,然后单独处理后两行进行建树,建完树后中序输出,然后通过map找到对应的键值是否为升序,是笛卡尔树的第二个条件是  该树的除叶节点外,其余结点的值都比左右孩子的值大 
*/ #include<bits/stdc++.h>
using namespace std;typedef struct TNode* ptrTree;
typedef struct TNode{int data;ptrTree left;ptrTree right;
}tnode;int cnt;//记录递归次数 
vector<int>v; //存中序遍历的序号 
map<int,int>m1,m2;//存前两行的数据 
int flag2 = 0;//用于判断K2 ptrTree createTree(int number[1000][2],int x){if(x == -1)return NULL;cnt++;ptrTree BT = (ptrTree)malloc(sizeof(struct TNode));BT->left = NULL;BT->right = NULL;BT->data = x;
//	cout << BT->data << endl;BT->left = createTree(number,number[x][0]);BT->right = createTree(number,number[x][1]);return BT; 
}//中序遍历
void inorder(ptrTree BT){if( BT ){inorder(BT->left);int temp = BT->data;v.push_back(temp);inorder(BT->right); }} //是笛卡尔树的第二个判断条件
void judgement(ptrTree BT){if( BT->left != NULL ){if(m2[BT->data] > m2[BT->left->data]){flag2 = 1;return ;}judgement(BT->left);}if( BT->right != NULL ){if(m2[BT->data] > m2[BT->right->data]){flag2 = 1;return ;	}judgement(BT->right);}} int main(){int N,flag1 = 0;int array[1000][2];//定义二维数组存储后两行的数据int m;//记录根节点用的 cin >> N;for( int i = 0; i < N; i++ ){int a,b,c,d;cin >> a >> b >> c >> d;m1[i] = a; m2[i] = b;//存储前两行数据array[i][0] = c;  array[i][1] = d;//存储后两行数据 } for( int i = 0; i < N;  i++){//建树cnt = 0;ptrTree BT; BT= createTree(array,i); //这种建树方法 其实指定根节点最好 但如果没有的话//那就挨个进行建树 如果其递归次数达到结点数目,那么就建树正确 if(cnt == N){inorder(BT);//将中序遍历的顺序存入 vector中 judgement(BT);//条件K2 break;}}if( flag2 == 1)cout << "NO"; else{for(int i = 0; i < v.size()-1; i++){if( m1[v[i]] > m1[v[i+1]]){cout << "NO";flag1 = 1;break;}			}}if(flag1 == 0 && flag2 == 0 )cout << "YES";} //测试测试点三  即K2的判断
//6
//8 27 5 1
//9 25 -1 -1
//10 20 0 3
//12 21 -1 4
//15 22 -1 -1
//5 35 -1 -1

在这里插入图片描述

四:总结

我在分析题意时 以为 K2的判断条件为 只要根节点的关键值最小就OK,其实不然应该是所有非叶结点的值都大于其左右孩子,这样导致测试点三一直过不去,然后我就重新分析题意,发现自己的逻辑错误,然后就找样例就行验证自己猜想,结果验证正确。我想说的是啥呢,就是在做题当中即便有一个点不过,也不要放弃,继续死磕,回归题目是根本,重新梳理逻辑。加油BOY!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/308409.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java ee导入后乱码_JavaEE中为什么出现中文乱码?

1.原因客户端通过IE提交时用的默认编码是UTF-8&#xff0c;而当我们用Myeclipse的时候的服务端接受的时候用的是iso-8859-12.解决方法服务端也用UTF-8编码byte[] result request.getParameter("titile").getBytes("iso-8859-1") ;title new String(resu…

Java多线程之龟兔赛跑和抢票

一&#xff1a;引言 练习这个码主要是为了体验在实现 多线程的方式中 实现Runable接口的好处&#xff0c;其中之一 有共享资源 &#xff0c;一个实现类但可以有多个代理 二&#xff1a;龟兔赛跑 package com.wyj.one; /*** 实现Runable接口也就是可以共享资源* author 86155…

不仅性能秒杀Hadoop,现在连分布式集群功能也开源了

就在昨天&#xff08;2020年8月3日&#xff09;&#xff0c;涛思数据团队正式宣布&#xff0c;物联网大数据平台TDengine集群版开源。此次开源&#xff0c;我们在GitHub上传了23.9万行源代码&#xff0c;1198个源文件&#xff0c;包含我自己疫情期间写的一万余行C代码&#xff…

php 将中文字符转英文字母_php 中英文语言转换类

起初想到制成XML文档形式&#xff0c;这样操作也起来很容易。只是看到说XML效率不怎样再者就是不同的模板&#xff0c;可这样也有个小问题&#xff0c;有些词汇比如时间提示是不确定&#xff0c;与可能是minute &#xff0c;day。也有可能复数加 s那好吧&#xff0c;做成数组&a…

7-32 哥尼斯堡的“七桥问题” (25 分)(思路+详解+题目分析)两种做法任选其一

一&#xff1a;题目&#xff1a; 哥尼斯堡是位于普累格河上的一座城市&#xff0c;它包含两个岛屿及连接它们的七座桥&#xff0c;如下图所示。 可否走过这样的七座桥&#xff0c;而且每桥只走过一次&#xff1f;瑞士数学家欧拉(Leonhard Euler&#xff0c;1707—1783)最终解…

.NET 异步详解(更新)

前言博客园&#xff08;cnblogs.com&#xff09;中有很多关于 .NET async/await 的介绍&#xff0c;但是很遗憾&#xff0c;很少有正确的&#xff0c;甚至说大多都是“从现象编原理”都不过分。最典型的比如通过前后线程 ID 来推断其工作方式、在 async 方法中用 Thread.Sleep …

Java中关于单核处理多个线程的认识与了解

一&#xff1a;单核执行多线程 1. 首先要知道 进程&#xff0c;线程&#xff0c;程序进程&#xff1a;执行中的程序叫做进程(Process)&#xff0c;是一个动态的概念&#xff0c;在一个进程中包含多个线程线程&#xff1a;指的是一条执行路径程序&#xff1a;就是静态的代码块2…

一次简单的服务器 cpu 占用率高的快速排查实战

前两天&#xff0c;朋友遇到一个线上 cpu 占用率很高的问题&#xff0c;我们俩一起快速定位并解决了这个问题。在征求朋友同意后&#xff0c;特发此文分享整个过程。本文以对话的形式展开&#xff0c;加上我的内心独白。文中对话与实际对话略有出入。友&#xff1a; 在吗&#…

php文件直链源码,PHP萌心上传直链外链网盘源码

源码说明PHP萌心上传直链外链网盘源码&#xff0c;小巧单文件&#xff0c;无需数据库&#xff0c;只需PHP运行环境即可。源码安装方法上传文件到PHP运行环境&#xff0c;修改index.php内的配置// 单个文件限制$max_file_size"51200";//大小指的KB&#xff0c;51200是…

7-33 地下迷宫探索 (30 分)(思路加详解)

一&#xff1a;题目 7-33 地下迷宫探索 (30 分)地道战是在抗日战争时期&#xff0c;在华北平原上抗日军民利用地道打击日本侵略者的作战方式。地道网是房连房、街连街、村连村的地下工事&#xff0c;如下图所示。 我们在回顾前辈们艰苦卓绝的战争生活的同时&#xff0c;真心钦…

php如何判断二维数组为空,PHP判断数组为空的具体方式

在学习PHP语言的时候&#xff0c;初学者往往会对数组感到一些棘手。不过在通过深入的学习之后&#xff0c;我们会发现&#xff0c;这些其实并没有想象中的困难。我们今天就要向大家介绍PHP判断数组为空的具体方式&#xff0c;希望能让新手们了解一些新知识。PHP判断数组为空之一…

联通定时休眠5G基站 戳破皇帝的新衣

近年来&#xff0c;5G被欧美政客、大公司、媒体连番炒作&#xff0c;在公开舆论上&#xff0c;5G成为了“科技制高点”&#xff0c;成为决定国家命运的“外星科技”&#xff0c;个别明星企业家还声称&#xff0c;“5G改变社会”&#xff0c;“5G应用后美国将成为落后国家”。但…

java中的线程不安全和实例解析

一&#xff1a;引言&#xff08;特指单核&#xff09; 所谓线程不安全&#xff0c;就是在共享数据时&#xff0c;不同的线程在执行时&#xff0c;出现数据的不准确&#xff0c;&#xff08;以模拟抢票和模拟银行取钱为例&#xff09;&#xff0c;那么我们的线程不安全具体指的…

记近一年线上项目经验及架构变更记录

简介M 项目, 是一个电子社保业务系统&#xff0c;2019.8 月团队接手了这个项目的开发工作&#xff0c;到 2020.7 月客户的业务量翻了&#xff14;倍&#xff0c;工作日同时在线员工数量&#xff14;&#xff10;人&#xff0c;以下记录总结 2019.8-至今项目的架构变化&#xff…

拓扑排序C++实现+实例解析(详解 兄弟们冲呀呀呀呀呀呀呀)

一&#xff1a;引言 既然是一种排序&#xff0c;那么肯定是按照某种规则进行排序&#xff0c;那么这么想的话&#xff0c;先了解基本知识&#xff0c;再来实战演练 1. AOV网&#xff08;Activity On Vertex Network)【顶点——表示活动】 是一个——有向无回路的图 顶点——表…

php yaf smarty,Yaf 结合用户自定义的视图(模板)引擎Smarty(Yaf + Smarty)

Yaf 结合用户自定义的视图(模板)引擎Smarty(Yaf Smarty)来源&#xff1a;互联网作者&#xff1a;佚名时间&#xff1a;2015-08-06 07:55对完成某个任务进行计时可使用progress_timer类&#xff0c;这个类对象在退出作用范围后&#xff0c;会输出对象创建后过去的时间&#xff…

7-34 任务调度的合理性 (25 分)(思路加详解+兄弟们冲呀)

一&#xff1a;题目 假定一个工程项目由一组子任务构成&#xff0c;子任务之间有的可以并行执行&#xff0c;有的必须在完成了其它一些子任务后才能执行。“任务调度”包括一组子任务、以及每个子任务可以执行所依赖的子任务集。 比如完成一个专业的所有课程学习和毕业设计可…

.NET和.NET Core Web APi FormData多文件上传

【导读】最近因维护.NET和.NET Core项目用到文件上传功能&#xff0c;虽说也做过&#xff0c;但是没做过什么对比&#xff0c;借此将二者利用Ajax通过FormData上传文件做一个总结&#xff0c;通过视图提交表单太简单&#xff0c;这里不做阐述&#xff0c;希望对有需要的童鞋能有…

php 百度云 上传,求个PHP版百度云BOS上传文件的dome

[HTML] 纯文本查看 复制代码bce-bos-uploader simple demo开始上传var uploader new baidubce.bos.Uploader({browse_button: #file,bos_bucket: ,bos_endpoint: ,bos_ak: ,bos_sk: ,max_file_size: 1Gb,init: {FileUploaded: function (_, file, info) {var bucket info.bod…

在ubuntu上实现基于webrtc的多人在线视频聊天服务

最近研究webrtc视频直播技术&#xff0c;网上找了些教程最终都不太能顺利跑起来的&#xff0c;可能是文章写的比较老&#xff0c;使用的一些开源组件已经更新了&#xff0c;有些配置已经不太一样了&#xff0c;所以按照以前的步骤会有问题。折腾了一阵终于跑起来了&#xff0c;…