如果二叉树每个节点都具有相同的值,那么该二叉树就是单值二叉树。
只有给定的树是单值二叉树时,才返回true;否则返回false。
//题目框架
bool isUnivalTree(struct TreeNode* root){
}
很多老铁看到这道题,一上来会选择直接遍历二叉树来试图解决这道题。当然遍历固然可行,这道题使用二叉树的前中后遍历的方式来解决,虽然实现的过程存在一定的差异,但都能做出来。
这里给出前序遍历的实现,以便参考。
前序遍历,无非是先判断根节点,在判断左右子树。根节点的值不一样,返回false,左右子树中任何一方存在节点的值不一样都返回false。
bool PreOrderCompare(struct TreeNode* root, int val)
{
if(NULL == root)
{
return true;
}
//先判断根节点
if(val != root->val)
{
return false;
}
//在判断左右子树
return PreOrderCompare(root->left,val) && PreOrderCompare(root->right,val);
}
bool isUnivalTree(struct TreeNode* root)
{
if(NULL == root)
{
return true;
}
//比较后,所有的值都相同返回true;存在有的值不相同返回false.
return PreOrderCompare(root, root->val);
}
但是,我这里想给出另一种非遍历比较的方法。
要判断一棵二叉树的每个结点是否都具有相同的值,只要判断这棵二叉树的根节点、左子树、右子树是否都是相同的值即可。
如果左子树节点的值==根节点的值 并且 右子树节点的值==根节点的值,那么由等式的传递性,就可以知道这棵二叉树是单值二叉树。
所以,可以给出参考代码如下:
bool isUnivalTree(struct TreeNode* root)
{
if(NULL == root)
{
return true;
}
//判断左子树的值是否等于根节点的值
if(root->left!=NULL && root->left->val!=root->val)
{
return false;
}
//判断右子树的值是否等于根节点的值
if(root->right!=NULL && root->right->val!=root->val)
{
return false;
}
//接着从左右子树的根节点开始判断
return isUnivalTree(root->left) && isUnivalTree(root->right);
}
这种比较判断的方法,本质也是利用了类似前序遍历的方式来解决的。
有小伙伴想使用中序遍历或后序遍历来解决这个问题,其实从分析来看是不太好的。
因为,假设整棵树的根节点的值就是那个异同的值,或者异同的值在整棵树比较靠上的层次。中序遍历和后序遍历都是在后来才遍历根节点,需要先去树里面找一圈回来才发现有一个异同的值,这样的话就增加了不必要的遍历。虽然问题能解决,但肯定不是优解。
注意:如果二叉树为空的话,其实并不违背单值二叉树的定义,也就是二叉树中并不存在不相等的值,所以仍然可以把空树看作单值二叉树。以上代码也是如此处理的。
给你两棵二叉树的根节点p和q,编写一个函数来检验这两棵树是否相同。
如果两个树在结构上相同,并且节点具有相同的值,则认为它们是相同的。
//题目框架
bool isSameTree(struct TreeNode* p, struct TreeNode* q){
}
判断这两棵二叉树是否相同,只要判断根节点相同,并且左右子树相同即可。
但只要根节点,或者左右子树有一个不相同,那就返回false。
同时要注意树是否为空的情况处理。
bool isSameTree(struct TreeNode* p, struct TreeNode* q)
{
//两棵树都为空的情况
if(NULL==p&&NULL==q)
{
return true;
}
//一棵树为空,一棵树不为空的情况
if(NULL==p||NULL==q)
{
return false;
}
//判断根节点
if(p->val!=q->val)
{
return false;
}
//判断左右子树
return isSameTree(p->left,q->left) && isSameTree(p->right,q->right);
}
上述代码,仍是以前序遍历的思想来解决的。
给你一个二叉树的根节点root, 检查它是否轴对称。

//题目框架
bool isSymmetric(struct TreeNode* root){
}
从上图中可以看出,二叉树中整棵树的根节点对于判断该二叉树是否对称影响并不大。
所以,如果根节点为空,直接判断它是对称的(其实空树并不违背对称的性质)。
如果整棵二叉树的根节点不为空,就去判断它的左右子树是否符合对称的性质即可。
但是要说明的是,子树中的根节点已经不能像整棵二叉树的根节点那样进行同样的处理了。至于原因看图就懂了😉。
所以,从上面分析之后,我们可以将代码分成两部分来处理。如下面所示。
bool isSymmetricSubTree(struct TreeNode* root1,struct TreeNode* root2)
{
//这两个if用法和《相同的树》代码中的用法是一致的
if(root1==NULL&&root2==NULL)
{
return true;
}
if(root1==NULL||root2==NULL)
{
return false;
}
//根节点值的判断
if(root1->val!=root2->val)
{
return false;
}
//注意:此处因为是进行对称的判断,由镜像对称的性质,可以知道,left和right是镜像对称点,所以传值不要弄错了
return isSymmetricSubTree(root1->left,root2->right) && isSymmetricSubTree(root1->right,root2->left);
}
bool isSymmetric(struct TreeNode* root)
{
//二叉树的根节点为空
if(NULL==root)
{
return true;
}
//二叉树的根节点不为空
return isSymmetricSubTree(root->left,root->right);
}
给你两棵二叉树root和subRoot。检验root中是否包含和subRoot具有相同结构和节点值的子树。如果存在,返回true;否则,返回false。
二叉树tree的一棵子树包括tree的某个节点和这个节点的所有后代节点。tree也可以看做它自身的一棵子树。
root树上的节点数量范围是[1, 2000]
subRoot树上的节点数量范围是[1, 1000]

//题目框架
bool isSubtree(struct TreeNode* root, struct TreeNode* subRoot){
}
认真分析之后会发现,这个题就是是《相同的树》的变相问法。
为什么这么说呢?
其实,要判断subRoot的子树是否在root的树之中,肯定要去root树中去找呀(你这不废话吗😓)。
嘿嘿别急,既然去找,那如何去找呢?答案无非就是遍历了呗。
所以,其实就这么简单。
遍历root的每个节点,并都看做其所在子树的根节点,然后使用《相同的树》的判断方法,去和subRoot所在的子树进行比较。如果相同返回true,遍历完后还没找到,就返回false。
鉴于此,可得如下代码:
//采用前序遍历
bool isSubtree(struct TreeNode* root, struct TreeNode* subRoot)
{
if(isSameTree(root,subRoot))
{
return true;
}
//左右子树中有一个找到了,就返回true.
return isSubtree(root->left,subRoot) || isSubtree(root->right,subRoot);
}
说明:这个题是来自牛客网的,在力扣上没能找到,大家见谅了。
编一个程序,读入用户输入的一串先序遍历字符串,根据此字符串建立一个二叉树(以指针方式存储)。 例如如下的先序遍历字符串: ABC##DE#G##F### 其中“#”表示的是空格,空格字符代表空树。建立起此二叉树以后,再对二叉树进行中序遍历,输出遍历结果。
输入包括1行字符串,长度不超过100。
这道题归根到底主要在于二叉树的创建。题目给出了二叉树的前序遍历字符串(带空节点),那咱也自然按照前序的方式来建树(此建树非彼建树,哈哈😜)了。
其实大多数的时候也只能是用前序的方式来建立树了。如果没有根节点的话,生成的左右子树节点的地址就不能直接被保存在根节点的指针域中。而将这些地址保存起来,最终放到后来生成的根节点中的话,想想就比较麻烦,不如使用前序遍历来得直接。另外从自然发展的角度来看的话,如果一棵树连根都没有,那它又如何能枝繁叶茂呢。
也就是说,使用先序遍历来建树,先建立根节点,再建立根节点的左子树,再建立根节点的右子树。如果是空节点#,就返回NULL,不是空节点,就返回创建的root节点。
根据此思路,可以给出二叉树前序创建的代码:
//str代表前序遍历的字符串
//pi是记录字符串下标的地址
struct TreeNode* CreateTree(char* str, int* pi)
{
//遇到‘#’,返回NULL
if('#'==str[*pi])
{
(*pi)++;
return NULL;
}
//先创建根节点,在创建左子树,再创建右子树,最后返回根节点
struct TreeNode* root=BuyNode(str[(*pi)++]);
root->left = CreateTree(str,pi);
root->right = CreateTree(str,pi);
return root;
}
好了,通过上面的代码将二叉树创建出来以后,只需再中序遍历一遍,打印输出就OK了。
完整代码如下:
#include <stdio.h>
#include <stdlib.h>
#include <assert.h>
//二叉树节点定义
struct TreeNode
{
char val;
struct TreeNode* left;
struct TreeNode* right;
};
//生成一个节点
struct TreeNode* BuyNode(char c)
{
struct TreeNode* newNode = (struct TreeNode*)malloc(sizeof(struct TreeNode));
assert(newNode);
newNode->val=c;
newNode->left=NULL;
newNode->right=NULL;
return newNode;
}
struct TreeNode* CreateTree(char* str, int* pi)
{
if('#'==str[*pi])
{
(*pi)++;
return NULL;
}
struct TreeNode* root=BuyNode(str[(*pi)++]);
root->left = CreateTree(str,pi);
root->right = CreateTree(str,pi);
return root;
}
//中序遍历打印
void InOrderPrint(struct TreeNode* root)
{
if(NULL==root)
{
return;
}
InOrderPrint(root->left);
printf("%c ", root->val);
InOrderPrint(root->right);
}
int main()
{
char str[101]={0};
scanf("%s",str);
int i=0;
struct TreeNode* root = CreateTree(str, &i);
InOrderPrint(root);
return 0;
}
1.postman介绍Postman一款非常流行的API调试工具。其实,开发人员用的更多。因为测试人员做接口测试会有更多选择,例如Jmeter、soapUI等。不过,对于开发过程中去调试接口,Postman确实足够的简单方便,而且功能强大。2.下载安装官网地址:https://www.postman.com/下载完成后双击安装吧,安装过程极其简单,无需任何操作3.使用教程这里以百度为例,工具使用简单,填写URL地址即可发送请求,在下方查看响应结果和响应状态码常用方法都有支持请求方法:getpostputdeleteGet、Post、Put与Delete的作用get:请求方法一般是用于数据查询,
Ⅰ软件测试基础一、软件测试基础理论1、软件测试的必要性所有的产品或者服务上线都需要测试2、测试的发展过程3、什么是软件测试找bug,发现缺陷4、测试的定义使用人工或自动的手段来运行或者测试某个系统的过程。目的在于检测它是否满足规定的需求。弄清预期结果和实际结果的差别。5、测试的目的以最小的人力、物力和时间找出软件中潜在的错误和缺陷6、测试的原则28原则:20%的主要功能要重点测(eg:支付宝的支付功能,其他功能都是次要的)80%的错误存在于20%的代码中7、测试标准8、测试的基本要求功能测试性能测试安全性测试兼容性测试易用性测试外观界面测试可靠性测试二、质量模型衡量一个优秀软件的维度①功能性功
ES一、简介1、ElasticStackES技术栈:ElasticSearch:存数据+搜索;QL;Kibana:Web可视化平台,分析。LogStash:日志收集,Log4j:产生日志;log.info(xxx)。。。。使用场景:metrics:指标监控…2、基本概念Index(索引)动词:保存(插入)名词:类似MySQL数据库,给数据Type(类型)已废弃,以前类似MySQL的表现在用索引对数据分类Document(文档)真正要保存的一个JSON数据{name:"tcx"}二、入门实战{"name":"DESKTOP-1TSVGKG","cluster_name":"elasticsear
1.在Python3中,下列关于数学运算结果正确的是:(B)a=10b=3print(a//b)print(a%b)print(a/b)A.3,3,3.3333...B.3,1,3.3333...C.3.3333...,3.3333...,3D.3.3333...,1,3.3333...解析: 在Python中,//表示地板除(向下取整),%表示取余,/表示除(Python2向下取整返回3)2.如下程序Python2会打印多少个数:(D)k=1000whilek>1: print(k)k=k/2A.1000 B.10C.11D.9解析: 按照题意每次循环K/2,直到K值小于等
ValidPalindromeGivenastring,determineifitisapalindrome,consideringonlyalphanumericcharactersandignoringcases. [#125]Example:"Aman,aplan,acanal:Panama"isapalindrome."raceacar"isnotapalindrome.Haveyouconsiderthatthestringmightbeempty?Thisisagoodquestiontoaskduringaninterview.Forthepurposeofthisproblem
我一直在尝试在Ruby中实现BinaryTree类,但我得到了stackleveltoodeep错误,尽管我似乎没有在该特定代码段中使用任何递归:1.classBinaryTree2.includeEnumerable3.4.attr_accessor:value5.6.definitialize(value=nil)7.@value=value8.@left=BinaryTree.new#stackleveltoodeephere9.@right=BinaryTree.new#andhere10.end11.12.defempty?13.(self.value==nil)?true:
(本文是网络的宏观的概念铺垫)目录计算机网络背景网络发展认识"协议"网络协议初识协议分层OSI七层模型TCP/IP五层(或四层)模型报头以太网碰撞路由器IP地址和MAC地址IP地址与MAC地址总结IP地址MAC地址计算机网络背景网络发展 是最开始先有的计算机,计算机后来因为多项技术的水平升高,逐渐的计算机变的小型化、高效化。后来因为计算机其本身的计算能力比较的快速:独立模式:计算机之间相互独立。 如:有三个人,每个人做的不同的事物,但是是需要协作的完成。 而这三个人所做的事是需要进行协作的,然而刚开始因为每一台计算机之间都是互相独立的。所以前面的人处理完了就需要将数据
前言我们习惯用idea编写、调试代码,在LeetCode上刷题时,如果能够在IDEA编写代码,并且做好代码管理,是一件事半功倍的事情。对于后续复习题目,做笔记也会非常便利。本文目的在于介绍LeetCodeEditor的使用,以及配置工具类,最终目录结构如下:note:放置笔记src:放置代码leetcode.editor.cn:插件LeetCodeEditor自动生成utils:自定义的工具包,可用于自动化输入测试用例,定义题目需要的类(结构体)out:运行测试时自动生成LeetCodeEditorGitHub:https://github.com/shuzijun/leetcode-edit
文章目录概念索引相关操作创建索引更新副本查看索引删除索引索引的打开与关闭收缩索引索引别名查询索引别名文档相关操作新建文档查询文档更新文档删除文档映射相关操作查询文档映射创建静态映射创建索引并添加映射概念es中有三个概念要清楚,分别为索引、映射和文档(不用死记硬背,大概有个印象就可以)索引可理解为MySQL数据库;映射可理解为MySQL的表结构;文档可理解为MySQL表中的每行数据静态映射和动态映射上面已经介绍了,映射可理解为MySQL的表结构,在MySQL中,向表中插入数据是需要先创建表结构的;但在es中不必这样,可以直接插入文档,es可以根据插入的文档(数据),动态的创建映射(表结构),这就
目录1关系运算符2运算符优先级3关系表达式的书写代码实例:下面是面试中可能遇到的问题:1关系运算符C++中有6个关系运算符,用于比较两个值的大小关系,它们分别是:运算符描述==等于!=不等于小于>大于小于等于>=大于等于这些运算符返回一个布尔值,即true或false。例如,当x等于y时,x==y的结果为true,否则结果为false。2运算符优先级在C++中,关系运算符的优先级高于赋值运算符,但低于算术运算符。以下是关系运算符的优先级,从高到低排列:运算符描述>,,>=,关系运算符==,!=相等性运算符&&逻辑与`如果在表达式中有多个运算符,则按照优先级顺序依次进行运算。3关系表达式的书写在