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

湛江做网站说去哪找想做网站的客户

湛江做网站说,去哪找想做网站的客户,wordpress升级快速,四川企业宣传片制作公司二叉树的Morris(莫里斯)遍历 本文参考链接#xff1a;https://leetcode.cn/problems/binary-tree-preorder-traversal/submissions/490846864/ 文章目录 二叉树的Morris(莫里斯)遍历模板代码前序遍历中序遍历后序遍历 Morris 遍历使用二叉树节点中大量指向 null 的指针…二叉树的Morris(莫里斯)遍历 本文参考链接https://leetcode.cn/problems/binary-tree-preorder-traversal/submissions/490846864/ 文章目录 二叉树的Morris(莫里斯)遍历模板代码前序遍历中序遍历后序遍历 Morris 遍历使用二叉树节点中大量指向 null 的指针时间复杂度O(n)额外空间复杂度O(1)。 Morris 的整体思路就是将 以某个根结点开始找到它左子树的最右侧节点之后与这个根结点进行连接。 我们可以从图中看到连接之后指针是可以完整的从根节点顺着下一个节点遍历将整棵树遍历完毕直到 7 这个节点右侧没有指向。 模板代码 首先介绍morris的模板代码带*的注释表示该行为指定遍历所要增加的内容可以先不管。 模板代码的流程图如下所示 public ListInteger traversal(TreeNode root) {ListInteger res new ArrayList();if (root null) {return res;}//1.定义cur和prevTreeNode cur root;TreeNode prev null;//2.当cur不为空时while (cur ! null) {//2.1prev为cur左子树prev cur.left;//2.2prev不为空时if (prev ! null) {//2.2.1用prev找到左子树最右侧节点while (prev.right ! null prev.right ! cur) {prev prev.right;}//2.2.2prev右子树不为空时连接if (prev.right null) {prev.right cur;//*前res.add(cur.val);cur cur.left;} else { //2.2.3prev右子树不为空时断开连接prev.right null;//*中res.add(cur.val); *后print(cur.left)cur cur.right;}} else { //2.3prev为空时//*前中res.add(cur.val);cur cur.right;}}//*后print(root)return res; }前序遍历 public ListInteger preorderTraversal(TreeNode root) {ListInteger res new ArrayList();if (root null) {return res;}//1.定义cur和prevTreeNode cur root;TreeNode prev null;//2.当cur不为空时while (cur ! null) {//2.1prev为cur左子树prev cur.left;//2.2prev不为空时if (prev ! null) {//2.2.1用prev找到左子树最右侧节点while (prev.right ! null prev.right ! cur) {prev prev.right;}//2.2.2prev右子树不为空时连接if (prev.right null) {prev.right cur;res.add(cur.val);cur cur.left;} else { //2.2.3prev右子树不为空时断开连接prev.right null;cur cur.right;}} else { //2.3prev为空时res.add(cur.val);cur cur.right;}}return res; } 中序遍历 public ListInteger inorderTraversal(TreeNode root) {ListInteger res new ArrayList();if (root null) {return res;}//1.定义cur和prevTreeNode cur root;TreeNode prev null;//2.当cur不为空时while (cur ! null) {//2.1prev为cur左子树prev cur.left;//2.2prev不为空时if (prev ! null) {//2.2.1用prev找到左子树最右侧节点while (prev.right ! null prev.right ! cur) {prev prev.right;}//2.2.2prev右子树不为空时连接if (prev.right null) {prev.right cur;cur cur.left;} else { //2.2.3prev右子树不为空时断开连接prev.right null;res.add(cur.val);cur cur.right;}} else { //2.3prev为空时res.add(cur.val);cur cur.right;}}return res; }后序遍历 当连接已完成时断开连接后打印下层的单链表比如返回到2时打印4返回到1时打印52涉及到了逆序打印单链表的内容。注意应该是打印下一层而不是当前层。循环结束后打印根节点所在的一侧即731。 ListInteger res new ArrayList(); public ListInteger postorderTraversal(TreeNode root) {if (root null) {return res;}//1.定义cur和prevTreeNode cur root;TreeNode prev null;//2.当cur不为空时while (cur ! null) {//2.1prev为cur左子树prev cur.left;//2.2prev不为空时if (prev ! null) {//2.2.1用prev找到左子树最右侧节点while (prev.right ! null prev.right ! cur) {prev prev.right;}//2.2.2prev右子树不为空时连接if (prev.right null) {prev.right cur;cur cur.left;} else { //2.2.3prev右子树不为空时断开连接prev.right null;print(cur.left); //打印左子树cur cur.right;}} else { //2.3prev为空时cur cur.right;}}print(root); //打印根节点所在一侧return res; }//打印链表 public void print(TreeNode head) {TreeNode revList reverseList(head);TreeNode cur revList;while (cur ! null) {res.add(cur.val);cur cur.right;}reverseList(revList); }//翻转单链表 public TreeNode reverseList(TreeNode head) {TreeNode cur head;TreeNode prev null;while (cur ! null) {TreeNode next cur.right;cur.right prev;prev cur;cur next;}return prev; }
http://www.zqtcl.cn/news/624880/

相关文章:

  • 免费建站系统博客海外网站搭建
  • 网站建设与制作视频教学站酷网图片
  • 网站开发还有哪些万维网申请网站域名
  • 做网站费用上海判断网站做的好坏
  • 有了域名和空间怎么建网站哪些公司需要网页电商设计师
  • 网站开站备案深圳创业补贴10万
  • 圆通我做网站拉上海建站系统
  • 对于做网站有什么要求新闻发布会视频
  • 网站建设专业就业前景成都房产信息网 官网
  • 西宁网站建设公司排行网站查询域名ip解析
  • 柳州企业网站开发公司如何做网站首页图
  • 刷赞网站空间免费深圳网站制作公司排名
  • 网站内部优化策略获取网站的路径
  • 网站群 优点今天西安最新通告
  • 惠济免费网站建设设计制作的广告公司
  • 做一个网站建设装潢设计属于什么专业
  • 水处理网站源码注册销售公司流程和费用
  • 诸城网站建设0536s整站优化seo排名点击
  • 企业建设网站需注意哪些内容苏州网站怎么做
  • 浏览器打开网站网站推广软件工具
  • 网站主题编辑工具WordPress公司网站策划方案
  • 做旅游网站选什么空间搜索引擎优化策略有哪些
  • 网站备案多少钱安全网站建设与服务的关系
  • 手机端网页设计尺寸规范优化seo排名
  • 做网站业务提成多少厦门十大装修公司排名榜
  • 为什么用开源建站wordpress rss 插件
  • 语文建设投稿网站南昌做网站的公司多不多
  • 石家庄网站建设的公司功能性质网站
  • 企业网站主页模板装饰公司名字起名大全
  • 马鞍山网站设计价格如何在微信公众号内部做网站