当前位置: 首页 > news >正文

石家庄网站建设高端信息门户网站建设

石家庄网站建设高端,信息门户网站建设,创意设计论坛,网络营销方式有哪些根据二叉树创建字符串 class Solution { public:/** ()的省略有两种情况* 1.左右都为空,省略* 2.左子树不为空,右子树为空,省略*/string tree2str(TreeNode* root){string s;if(root nullptr){return s;}s to_string(root->val);if(root…
  1. 根据二叉树创建字符串

在这里插入图片描述

class Solution {
public:/** ()的省略有两种情况* 1.左右都为空,省略* 2.左子树不为空,右子树为空,省略*/string tree2str(TreeNode* root){string s;if(root == nullptr){return s;}s += to_string(root->val);if(root->left){s += "(";s += tree2str(root->left);s +=")";}else if(root->right) // 为了应对左为空,右不为空的情况{s += "()";}if(root->right){s += "(";s += tree2str(root->right);s += ")";}return s;}
};
  1. 二叉树的层序遍历
class Solution {
public:vector<vector<int>> levelOrder(TreeNode* root){vector<vector<int>> vv;queue<TreeNode*> q;int levelSize = 0;if(root == nullptr){return vv;}q.push(root);vector<int> v;while(!q.empty()){v.resize(0);levelSize = q.size();while(levelSize--){if((q.front())->left){q.push((q.front())->left);}if((q.front())->right){q.push((q.front())->right);}v.push_back((q.front())->val);q.pop();}vv.push_back(v);}return vv;}
};
  1. 二叉树的层序遍历 II

只需将正着层序遍历的结果reverse()一下即可。

  1. 二叉树的最近公共祖先

在这里插入图片描述
在这里插入图片描述

class Solution {
public:bool FindPath(TreeNode* root, TreeNode* x, stack<TreeNode*>& st){if(root == nullptr){return false;}st.push(root);if(root == x){return true;}if(FindPath(root->left, x, st)){return true;}if(FindPath(root->right, x, st)){return true;}st.pop();return false;}TreeNode* lowestCommonAncestor(TreeNode* root, TreeNode* p, TreeNode* q){stack<TreeNode*> pPath, qPath;FindPath(root, p, pPath); // 找从根节点root到p的路径FindPath(root, q, qPath); // 找从根节点root到q的路径while(pPath.size() != qPath.size()){if(pPath.size() > qPath.size()){pPath.pop();} else{qPath.pop();}}while(pPath.top() != qPath.top()){pPath.pop();qPath.pop();}return pPath.top();}
};
  1. 二叉搜索树与双向链表

在这里插入图片描述
在这里插入图片描述

class Solution {
public:void InOrderConvert(TreeNode* cur, TreeNode*& prev){if(cur == nullptr){return;}InOrderConvert(cur->left, prev);// 双向链接cur->left = prev;if(prev){prev->right = cur;}// prev向后移prev = cur;InOrderConvert(cur->right, prev);}TreeNode* Convert(TreeNode* pRootOfTree){TreeNode* prev = nullptr;// 中序遍历进行链接InOrderConvert(pRootOfTree, prev);// 找头节点TreeNode* head = pRootOfTree;while(head && head->left){head = head->left;}return head;}
};
  1. 从前序与中序遍历序列构造二叉树

在这里插入图片描述

class Solution {
public:TreeNode* _buildTree(vector<int>& preorder, vector<int>& inorder, int& prei, int inbegin, int inend){// 子树区间确认是否继续递归创建子树if(inbegin > inend)return nullptr;// 前序创建树TreeNode* root = new TreeNode(preorder[prei++]);// 中序分割左右子树int ini = inbegin;while(ini <= inend){if(inorder[ini] == root->val)break;else++ini;}root->left = _buildTree(preorder, inorder, prei, inbegin, ini - 1);root->right = _buildTree(preorder, inorder, prei, ini + 1, inend);return root;}TreeNode* buildTree(vector<int>& preorder, vector<int>& inorder){int i = 0;return _buildTree(preorder, inorder, i, 0, inorder.size() - 1);}
};
  1. 从中序与后序遍历序列构造二叉树
class Solution {
public:TreeNode* _buildTree(vector<int>& inorder, vector<int>& postorder, int& posti, int inbegin, int inend){if(inbegin > inend)return nullptr;TreeNode* root = new TreeNode(postorder[posti--]);int ini = inbegin;while(ini <= inend){if(inorder[ini] == root->val)break;else++ini;}root->right = _buildTree(inorder, postorder, posti, ini + 1, inend);root->left = _buildTree(inorder, postorder, posti, inbegin, ini - 1);return root;}TreeNode* buildTree(vector<int>& inorder, vector<int>& postorder){int i = postorder.size() - 1;return _buildTree(inorder, postorder, i, 0, inorder.size() - 1);}
};
http://www.yayakq.cn/news/622605/

相关文章:

  • 做一个网站需要多大的空间wordpress获取标签页
  • 企业网站建设价格表王老吉网络营销案例分析
  • 学会网站建设总结iis7搭建aspx网站
  • python做网站的案例网站建设的缺陷
  • 网站建设-信科网络网站开发技术学习
  • 昆山商城网站建设办公室装修效果图简约大气
  • dede织梦仿站网站建设本机网站环境搭建
  • 网站制作手机网络运维工程师求职信
  • 厦门网站推广¥做下拉去118cr在线制作动画的网站
  • 龙岗区住房和建设局网站打不开东莞哪里开发app的
  • 网站优化的重要性阿克苏地区建设局网站
  • 繁体版 企业网站中山市建设局网站
  • 山西本土网站建设html5快速建站
  • 西安做网站哪里好济南做网站最好的单位
  • 网站建设公司接单上海网站搜索排名优化哪家好
  • 深圳企业医疗网站建设wordpress 301代码
  • 个人博客网站搭建店面设计属于什么设计
  • 地方网站系统山东济南网站建设公司哪家好
  • 申请学校网站建设申请书济南市建设局官网
  • 网站建设制作 企业站开发哪家好wordpress添加微信
  • 怎么看别人网站怎么做的优化erp软件有哪些
  • .net网站费用唐山网络运营推广
  • 电梯配件做外贸在哪个网站网站建设话术开场白
  • 长春建设厅官方网站开发购物商城app需要多少钱
  • 广州易网外贸网站建设网站的动画广告横幅怎么做的
  • 泉州企业自助建站博客网站首页设计
  • 建设网站网站名wordpress的hook
  • 免费网站代理访问泛微网络科技有限公司
  • 使用flask做前后端分离的网站网站模板文章资讯
  • 有关天猫网站建设的论文品牌宣传策略