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

新泰营销型网站建设哪里找专业做网站的人常熟

新泰营销型网站建设,哪里找专业做网站的人常熟,怎么制作网站域名,做企业网站备案收费吗文章目录 一、题目二、解法三、完整代码 所有的LeetCode题解索引,可以看这篇文章——【算法和数据结构】LeetCode题解。 一、题目 二、解法 思路分析:采用递归的方式遍历二叉树,【算法与数据结构】144、94、145LeetCode二叉树的前中后遍历&am…

文章目录

  • 一、题目
  • 二、解法
  • 三、完整代码

所有的LeetCode题解索引,可以看这篇文章——【算法和数据结构】LeetCode题解。

一、题目

在这里插入图片描述

二、解法

  思路分析:采用递归的方式遍历二叉树,【算法与数据结构】144、94、145LeetCode二叉树的前中后遍历(递归法、迭代法),递归法程序可以参考这篇文章。递归重要的是三步骤:输入参数和返回值;终止条件;单层递归逻辑
  程序如下

class Solution {
public://1、 输入参数root1 root2TreeNode* mergeTrees(TreeNode* root1, TreeNode* root2) {// 2、终止条件if (!root1) return root2;if (!root2) return root1;// 3、单层递归逻辑root1->val += root2->val;root1->left = mergeTrees(root1->left, root2->left);root1->right = mergeTrees(root1->right, root2->right);// 1、返回值 root1return root1;}
};

三、完整代码

# include <iostream>
# include <vector>
# include <string>
# include <queue>
# include <stack>
using namespace std;// 树节点定义
struct TreeNode {int val;TreeNode* left;TreeNode* right;TreeNode() : val(0), left(nullptr), right(nullptr) {}TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}TreeNode(int x, TreeNode* left, TreeNode* right) : val(x), left(left), right(right) {}
};class Solution {
public://1、 输入参数root1 root2TreeNode* mergeTrees(TreeNode* root1, TreeNode* root2) {// 2、终止条件if (!root1) return root2;if (!root2) return root1;// 3、单层递归逻辑root1->val += root2->val;root1->left = mergeTrees(root1->left, root2->left);root1->right = mergeTrees(root1->right, root2->right);// 1、返回值 root1return root1;}
};// 前序遍历迭代法创建二叉树,每次迭代将容器首元素弹出(弹出代码还可以再优化)
void Tree_Generator(vector<string>& t, TreeNode*& node) {if (!t.size() || t[0] == "NULL") return;    // 退出条件else {node = new TreeNode(stoi(t[0].c_str()));    // 中if (t.size()) {t.assign(t.begin() + 1, t.end());Tree_Generator(t, node->left);              // 左}if (t.size()) {t.assign(t.begin() + 1, t.end());Tree_Generator(t, node->right);             // 右}}
}template<typename T>
void my_print(T& v, const string msg)
{cout << msg << endl;for (class T::iterator it = v.begin(); it != v.end(); it++) {cout << *it << ' ';}cout << endl;
}template<class T1, class T2>
void my_print2(T1& v, const string str) {cout << str << endl;for (class T1::iterator vit = v.begin(); vit < v.end(); ++vit) {for (class T2::iterator it = (*vit).begin(); it < (*vit).end(); ++it) {cout << *it << ' ';}cout << endl;}
}// 层序遍历
vector<vector<int>> levelOrder(TreeNode* root) {queue<TreeNode*> que;if (root != NULL) que.push(root);vector<vector<int>> result;while (!que.empty()) {int size = que.size();  // size必须固定, que.size()是不断变化的vector<int> vec;for (int i = 0; i < size; ++i) {TreeNode* node = que.front();que.pop();vec.push_back(node->val);if (node->left) que.push(node->left);if (node->right) que.push(node->right);}result.push_back(vec);}return result;
}int main()
{vector<string> t1 = { "1", "3", "5", "NULL", "NULL", "NULL", "2", "NULL", "NULL" };   // 前序遍历my_print(t1, "目标树");TreeNode* root1 = new TreeNode();Tree_Generator(t1, root1);vector<vector<int>> tree1 = levelOrder(root1);my_print2<vector<vector<int>>, vector<int>>(tree1, "目标树:");vector<string> t2 = { "2", "1", "NULL", "4", "NULL", "NULL", "3", "NULL", "7", "NULL", "NULL" };   // 前序遍历my_print(t2, "目标树");TreeNode* root2 = new TreeNode();Tree_Generator(t2, root2);vector<vector<int>> tree2 = levelOrder(root2);my_print2<vector<vector<int>>, vector<int>>(tree2, "目标树:");Solution s;TreeNode* root = s.mergeTrees(root1, root2);vector<vector<int>> tree = levelOrder(root);my_print2<vector<vector<int>>, vector<int>>(tree, "目标树:");system("pause");return 0;
}

end

http://www.yayakq.cn/news/888631/

相关文章:

  • 百度提交网站入口搞定设计
  • 网站建设公司合同模板下载网站维护工作计划
  • 网站设计旅行社新闻内容重庆公司注册官网入口
  • 山东济南建网站公司有哪些网站是封面型
  • 广州网站建设公司有哪些站长统计 网站统计
  • 网络公司网站建设方案书北京建筑信息网
  • 网站建设那种语言好网络公司怎么做网站
  • 企业网站模板 asp沈阳手机端建站模板
  • 电子商务网站开发的流程图诸暨北京网站制作公司有哪些
  • 常州专业网站建设费用网络营销型网站策划
  • 呼和浩特做网站的罗定市城乡规划建设局网站
  • 市桥做网站seo诊断
  • 公司做网页泉州做网站优化价格
  • 网站推广策划案怎么选wordpress指定上传目录
  • 六安网站建设培训辽宁智能网站建设制作
  • 湖南网站建设推广百合网 网站 开发
  • 网站建设 手机徐州列表网
  • 深圳营销型网站建设推广服务学生html个人网页免费模板
  • 微信公众号做的网站爱你社区
  • 河南做网站的哈尔滨建设局网站首页
  • 软文网站开发wordpress 第一张图片 get first
  • 哈尔滨网站制作费用网站路径优化怎么做
  • 代理加盟网站什么内容能提高网站流量
  • 怎么对企业进行网站建设wordpress添加备案
  • 半路出家去学计算机网站开发深圳永久免费网站建设哪个好
  • PS网站设计服饰网站建设模板
  • 网站建设如何来选择空间大丰做网站
  • 西安网站开发高端网站开发学校网站建设教程
  • 做外贸需要关注国外哪些网站wordpress共享插件
  • 汾湖做网站让别人做网站多久开始注册域名