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

二级网页制作教程seo网络优化教程

二级网页制作教程,seo网络优化教程,手机营销型网站建设,品牌网站建设哪里好题目 226. 翻转二叉树 简单 给你一棵二叉树的根节点 root ,翻转这棵二叉树,并返回其根节点。 示例 1: 输入:root [4,2,7,1,3,6,9] 输出:[4,7,2,9,6,3,1]示例 2: 输入:root [2,1,3] 输出&am…

题目

226. 翻转二叉树

简单

给你一棵二叉树的根节点 root ,翻转这棵二叉树,并返回其根节点。

示例 1:

输入:root = [4,2,7,1,3,6,9]
输出:[4,7,2,9,6,3,1]

示例 2:

输入:root = [2,1,3]
输出:[2,3,1]

示例 3:

输入:root = []
输出:[]

提示:

  • 树中节点数目范围在 [0, 100] 内
  • -100 <= Node.val <= 100

c++ 代码一 (递归法)

class Solution {
public:TreeNode* invertTree(TreeNode* root) {if (root == NULL) return root;  // 如果根节点为空,直接返回该节点,不进行翻转操作swap(root->left, root->right);  // 交换当前节点的左右子树,实现翻转操作invertTree(root->left);         // 递归地对当前节点的左子树进行翻转invertTree(root->right);        // 递归地对当前节点的右子树进行翻转return root;                    // 返回翻转后的根节点}
};

以上是代码中的注释,解释了每一行代码的作用。

  • 如果根节点为空,直接返回根节点,不进行翻转操作。
  • 交换当前节点的左右子树,实现翻转操作。
  • 递归地对当前节点的左子树进行翻转。
  • 递归地对当前节点的右子树进行翻转。
  • 返回翻转后的根节点。

c++ 代码二 (迭代法(前序遍历))

class Solution {
public:TreeNode* invertTree(TreeNode* root) {if (root == NULL) return root;  // 如果根节点为空,直接返回该节点,不进行翻转操作stack<TreeNode*> st;  // 创建一个栈,用于存储待翻转的节点st.push(root);        // 将根节点入栈while (!st.empty()) {TreeNode* node = st.top();  // 取出栈顶节点作为当前节点st.pop();swap(node->left, node->right);  // 交换当前节点的左右子树,实现翻转操作if (node->right) st.push(node->right);  // 如果当前节点的右子树不为空,则将右子树节点入栈,准备进行翻转操作if (node->left) st.push(node->left);    // 如果当前节点的左子树不为空,则将左子树节点入栈,准备进行翻转操作}return root;  // 返回翻转后的根节点}
};

以上是代码中的注释,解释了每一行代码的作用。

  • 如果根节点为空,直接返回根节点,不进行翻转操作。
  • 创建一个栈,用于存储待翻转的节点。
  • 将根节点入栈。
  • 使用迭代法进行翻转操作:
    • 取出栈顶节点作为当前节点。
    • 交换当前节点的左右子树,实现翻转操作。
    • 如果当前节点的右子树不为空,则将右子树节点入栈,准备进行翻转操作。
    • 如果当前节点的左子树不为空,则将左子树节点入栈,准备进行翻转操作。
  • 返回翻转后的根节点。

c++ 代码三 (广度优先遍历)

class Solution {
public:TreeNode* invertTree(TreeNode* root) {queue<TreeNode*> que;  // 创建一个队列,用于存储待翻转的节点if (root != NULL) que.push(root);  // 如果根节点不为空,则将根节点入队列while (!que.empty()) {  // 当队列不为空时循环执行操作int size = que.size();  // 获取当前队列的大小,即当前层的节点数for (int i = 0; i < size; i++) {  // 遍历当前层的节点TreeNode* node = que.front();  // 取出队首节点作为当前节点que.pop();  // 出队列swap(node->left, node->right);  // 交换当前节点的左右子树,实现翻转操作if (node->left) que.push(node->left);  // 如果当前节点的左子树不为空,则将左子树节点入队列,准备进行翻转操作if (node->right) que.push(node->right);  // 如果当前节点的右子树不为空,则将右子树节点入队列,准备进行翻转操作}}return root;  // 返回翻转后的根节点}
};

以上是代码中的注释,解释了每一行代码的作用。

  • 创建一个队列,用于存储待翻转的节点。
  • 如果根节点不为空,则将根节点入队列。
  • 使用迭代法进行翻转操作:
    • 获取当前队列的大小,即当前层的节点数。
    • 遍历当前层的节点:
      • 取出队首节点作为当前节点。
      • 交换当前节点的左右子树,实现翻转操作。
      • 如果当前节点的左子树不为空,则将左子树节点入队列,准备进行翻转操作。
      • 如果当前节点的右子树不为空,则将右子树节点入队列,准备进行翻转操作。
  • 返回翻转后的根节点。

觉得有用的话可以点点赞,支持一下。

如果愿意的话关注一下。会对你有更多的帮助。

每天都会不定时更新哦  >人<  。

http://www.15wanjia.com/news/17283.html

相关文章:

  • 找公司做网站需要买服务器app开发费用一般多少钱
  • 给公司做网站和公众号需要多少钱百度seo优化培训
  • b2b外贸平台大全整站seo排名要多少钱
  • 做动态二维码的网站流量精灵app
  • 配置网站域名关键词搜索引擎
  • 自己做网站需不需要钱中国十大营销策划机构
  • 做网站的费用入什么科目自动的网站设计制作
  • 介绍一学一做视频网站吗网络营销的营销理念
  • 建站行业有哪些免费推广网站
  • 龙华做棋牌网站建设找哪家效益快软文范例大全800字
  • 做网站的框架网站优化排名金苹果下拉
  • 漂亮全屏网站seo排名赚挂机赚钱软件下载
  • 微信头像做国旗网站app下载推广平台
  • 政府英文网站建设产品怎么做推广和宣传
  • 网站里面送礼物要钱怎么做代码百度提交网站入口
  • wordpress网站名百度竞价推广的技巧
  • 医学类的网站做Google收录提交入口
  • 自己怎么做返利网站吗网站广告投放价格表
  • 潍坊做网站哪个公司好百度推广关键词越多越好吗
  • wordpress做公司网站网络营销公司注册找哪家
  • 推广自己的网站需要怎么做百度电话
  • wild合成版是哪个网站做的成都最新动态
  • 临城企业做网站除了91还有什么关键词
  • 网站如何实现qq登录功能网络营销实施方案
  • 服务器网站配置免费发布信息网网站
  • 临沂在线上网站建设百度竞价员
  • 那些语言可以做动态网站武汉seo 网络推广
  • 深圳网站建设制作订做2021最近最火的关键词
  • 昭通做网站公司海外网站cdn加速
  • 小孩和妈妈做网站淘大象关键词排名查询