数据结构--二叉树相关题2(OJ)

1.比较对称二叉树(镜像二叉树)

二叉树相关题1中第二题的变形题。先去看1哦!

左子树和右子树比较

复制代码
bool _isSymmetric(struct TreeNode* p, struct TreeNode* q)
{
	if (p == NULL && q == NULL)
		return true;
	//如果两个都为空则是相等的
	if (p == NULL || q == NULL)
		return false;//若一个为空,一个不为空
	if (p->val != q->val)//值不同
	{
		return false;

	}
	return isSameTree(p->left, q->right) && isSameTree(p->right, q->left);
}//反复递归
bool isSymmetric(struct TreeNode* root)
{
	return _isSymmetric(root->left, root->right);
}

2.二叉树的前序遍历

注意:返回的数组必须要开辟动态空间,并且,假定了访问的人会free,所以只用管mallooc就行了。

复制代码
//用前序遍历二叉树
//力扣规定如果返回数组,需要返回数组大小,就必须要知道这个数组的大小是多少(oj)
//先遍历一遍这个树,看是多少size
int TreeSize(struct TreeNode*root)
{
	return root == NULL ? 0 : TreeSize( root->left) + TreeSize(root->right) + 1;
}

//开辟空间
//returnSize输出型参数
// 传过去的是地址
// 下面解引用就可以改变里面的内容
// 就拿到了数组的大小是用来输出的


//形参//都用指针接受,这样可以进行更改
void   preOrder(struct TreeNode* root, int* a, int* pi)
{
	if (root == NULL)
		return;
	a[(*pi)++] = root->val;
	preOrder(root->left, a, pi);
	preOrder(root->right, a, pi);
}

int* preorderTraversal(struct TreeNode* root, int* returnSize)
{
	//解引用
	*returnSize = TreeSize(root);//得到root的大小
	int* a = (int*)malloc(sizeof(int) * (*returnSize));
	int i = 0;
	preOrder(root, a, &i);
	return a;//传的是数组
}
相关推荐
阿群今天学习了吗4 小时前
“鱼书”深度学习进阶笔记(3)第四章
人工智能·笔记·python·深度学习·算法
IT猿手4 小时前
2025年最新原创多目标算法:多目标酶作用优化算法(MOEAO)求解MaF1-MaF15及工程应用---盘式制动器设计,提供完整MATLAB代码
算法·数学建模·matlab·多目标优化算法·多目标算法
数据智能老司机7 小时前
图算法趣味学——最大流算法
数据结构·算法·云计算
秋难降8 小时前
【数据结构与算法】———深度优先:“死磕 + 回头” 的艺术
数据结构·python·算法
数据智能老司机8 小时前
图算法趣味学——图着色
数据结构·算法·云计算
数据智能老司机8 小时前
图算法趣味学——启发式引导搜索
数据结构·算法·云计算
John.Lewis9 小时前
数据结构初阶(8)二叉树的顺序结构 && 堆
c语言·数据结构·算法
SimonSkywalke9 小时前
基于知识图谱增强的RAG系统阅读笔记(七)GraphRAG实现(基于小说诛仙)(一)
算法
再睡一夏就好10 小时前
【排序算法】④堆排序
c语言·数据结构·c++·笔记·算法·排序算法
再睡一夏就好10 小时前
【排序算法】⑥快速排序:Hoare、挖坑法、前后指针法
c语言·数据结构·经验分享·学习·算法·排序算法·学习笔记