您的位置:首页 > 房产 > 家装 > 北京网站快速排名优化_微信小程序研发_成都网站seo收费标准_深圳疫情最新消息

北京网站快速排名优化_微信小程序研发_成都网站seo收费标准_深圳疫情最新消息

2025/1/31 22:49:08 来源:https://blog.csdn.net/2303_78940834/article/details/143314867  浏览:    关键词:北京网站快速排名优化_微信小程序研发_成都网站seo收费标准_深圳疫情最新消息
北京网站快速排名优化_微信小程序研发_成都网站seo收费标准_深圳疫情最新消息

题目

链接:leetcode链接

在这里插入图片描述


思路分析

前序遍历的顺序是:根 + 左子树 + 右子树
中序遍历的顺序是: 左子树 + 根 + 右子树

所以,我们可以通过前序遍历获得二叉树的根
可以通过中序遍历去分割二叉树,将二叉树分割成 左子树 根 右子树
然后递归操作即可。

遍历前序序列,前序序列中的每一个元素都是一颗子树的根节点

所以,我们需要一个变量i来遍历前序序列,注意,在递归中,我们需要引用或者指针来传递该参数

找到根节点之后,在中序遍历中去寻找这个根节点,就可以将中序遍历分成三段了。

然后递归调用即可。

注意:有一点比较坑,就是如何去处理空树,当我们要分割后的区间的长度为0的时候就是空树,在具体代码中,我们采用了区间的起始下标和结尾下标
当 起始下标 > 结尾下标 的时候,就出现了空树,返回nullptr即可


代码

TreeNode* build(vector<int>& preorder, vector<int>& inorder,int& prei,int inbegin,int inend){if(inbegin > inend)return nullptr;TreeNode* root = new TreeNode(preorder[prei]);int begin = inbegin,end = inend;int rooti = 0;while(begin <= end){if(inorder[begin] == root->val){rooti = begin;break;}begin++;}prei++;root->left = build(preorder,inorder,prei,inbegin,rooti-1);root->right = build(preorder,inorder,prei,rooti+1,inend);return root;}TreeNode* buildTree(vector<int>& preorder, vector<int>& inorder) {int i = 0;return build(preorder,inorder,i,0,inorder.size() - 1);}

变式题

题目:利用中序序列和后序序列构造二叉树

链接:leetcode链接

在这里插入图片描述


思路分析

和上面一样,思路大致相同

后序遍历找根(根在后面)
中序遍历分割子树

后序遍历的顺序是 左子树 + 右子树 + 根

与上面不同的是,

  1. 我们需要从后向前遍历后序遍历,i需要一直–
  2. 我们在构建好根节点之后,我们需要接着构造右子树,而并非左子树。

其余与上面几乎相同

代码

TreeNode* build(vector<int>& inorder,vector<int>& postorder,int& posti,int inbegin,int inend){if(inbegin > inend)return nullptr;TreeNode* root = new TreeNode(postorder[posti]);//后序遍历找根int begin = inbegin,end = inend;int rooti = 0;while(begin <= end)//中序遍历分割{if(inorder[begin] == root->val){rooti = begin;}begin++;}if(begin > end){cout << "很抱歉,中序序列和后序序列不匹配" << endl;exit(1);}posti--;root->right = build(inorder,postorder,posti,rooti+1,inend);root->left = build(inorder,postorder,posti,inbegin,rooti-1);return root;}TreeNode* buildTree(vector<int>& inorder, vector<int>& postorder) {int i = postorder.size() - 1;return build(inorder,postorder,i,0,inorder.size() - 1);}

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com