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

娄底建网站网络营销实训总结报告

娄底建网站,网络营销实训总结报告,东莞网站制作方案定制,wordpress 线报主题用了递归遍历,关于树的经典例题。 题目 递归 常规做法即递归了,不会写也得背下来。递归可以大致理解方法调用自身,先写中序遍历递归的方法,递归一定要有递归出口,当遍历到节点为空时返回,即已经找到了。…

用了递归遍历,关于树的经典例题。

题目

递归 

常规做法即递归了,不会写也得背下来。递归可以大致理解方法调用自身,先写中序遍历递归的方法,递归一定要有递归出口,当遍历到节点为空时返回,即已经找到了。可以看一下为什么是这三行,中序遍历为左中右顺序,那就可以先从根节点一直往左边找,直到找到最左边的节点,这是“递”,然后到了这个节点时第一个inorder就会return,即开始“归”了,返回上一个inorder是不是就是该节点了,直接下一步add将当前节点值加进list集,然后下一个inorder就是遍历右边的节点了,当然这时右边有节点也会一直遍历下去,然后这里的顺序还是符合中序遍历,因为每次执行add时都是把当前节点为根节点,这样递归反复,在当前节点的左节点会在上一步返回先,在当前节点的右节点也会在该节点进入list集后在下一步返回。然后在另一个方法引入,返回list集即可。

时间复杂度:O(n),空间复杂度:O(n)。 

/*** Definition for a binary tree node.* public class TreeNode {*     int val;*     TreeNode left;*     TreeNode right;*     TreeNode() {}*     TreeNode(int val) { this.val = val; }*     TreeNode(int val, TreeNode left, TreeNode right) {*         this.val = val;*         this.left = left;*         this.right = right;*     }* }*/
class Solution {public List<Integer> inorderTraversal(TreeNode root) {List<Integer> res = new ArrayList<Integer>();inorder(root, res);return res;}public void inorder(TreeNode root, List<Integer> res) {if (root == null) {return;}inorder(root.left, res);res.add(root.val);inorder(root.right, res);}
}

循环 

那要是不用递归怎么写,上述其实也可以看作是一个模拟栈,递归的时候隐式地维护了一个栈,而我们在迭代的时候需要显式地将这个栈模拟出来,用循环能让这个栈更明显。先用外循环看看这个栈是否为空,节点非空也即要遍历的节点,然后下一个节点又是节点非空,把当前节点压入栈,指针左移,不断找左节点入栈,直到节点空了即找不到了,该循环结束,然后就开始出栈。出栈时位于栈顶的元素先出,即最左的元素先出,加进结果集后,指针右移,继续寻找右边的节点看看能否进行出栈,然后如此反复,就又是一个中序遍历了,思路是跟递归是差不多的。不想写多一个whlie,就把while改为if然后后面几行用else括住也能达到类似的效果。

时间复杂度:O(n),空间复杂度:O(n)。

class Solution {public List<Integer> inorderTraversal(TreeNode root) {List<Integer> res = new ArrayList<Integer>();Deque<TreeNode> stk = new LinkedList<TreeNode>();while (root != null || !stk.isEmpty()) {while (root != null) {stk.push(root);root = root.left;}//一直往左找root = stk.pop();res.add(root.val);root = root.right;//指针右移}return res;}
}

Morris 中序遍历 

不使用任何辅助空间,用上前驱节点,省去了栈的空间复杂度。先把根节点及根节点的右节点部分看成一大块连到根节点的左节点部分的最右节点上,然后以这样的方式反复拆分,左节点就会在前面先遍历,像链表一样的顺序,不过改变了整个树的结构。

时间复杂度:O(n),空间复杂度:O(1)。

class Solution {public List<Integer> inorderTraversal(TreeNode root) {List<Integer> res = new ArrayList<Integer>();TreeNode pre = null;while(root!=null) {//如果左节点不为空,就将当前节点连带右子树全部挂到//左节点的最右子树下面if(root.left!=null) {pre = root.left;while(pre.right!=null) {pre = pre.right;}pre.right = root;//将root指向root的leftTreeNode tmp = root;root = root.left;tmp.left = null;//左子树为空,则打印这个节点,并向右边遍历	} else {res.add(root.val);root = root.right;}}return res;}
}

当不想改变树的结构时,也可以进行链表的模拟,当遍历完后,将前驱节点的指针恢复即可。

class Solution {public List<Integer> inorderTraversal(TreeNode root) {List<Integer> res = new ArrayList<Integer>();TreeNode pre = null;while (root != null) {if (root.left != null) {// pre 节点就是当前 root 节点向左走一步,然后一直向右走至无法走为止pre = root.left;while (pre.right != null && pre.right != root) {pre = pre.right;}// 让 pre 的右指针指向 root,继续遍历左子树if (pre.right == null) {pre.right = root;root = root.left;}// 说明左子树已经访问完了,我们需要断开链接else {res.add(root.val);pre.right = null;root = root.right;}}// 如果没有左孩子,则直接访问右孩子else {res.add(root.val);root = root.right;}}return res;}
}

 像树这种结构很适合用递归循环实现。

http://www.dt0577.cn/news/21827.html

相关文章:

  • java旅游网站开发论文网络站点推广的方法有哪些
  • 网站死链买号链接
  • 新兴街做网站公司全网关键词搜索工具
  • 重庆高端网站建设百度搜索指数在线查询
  • 自己做网站还是开淘宝产品推广词
  • 网站用绝对路径好还是相对路径seo许昌网站seo
  • wordpress 4.9.1 主题seo科技网
  • 泉州网站建设策划百度的广告怎么免费发布
  • 湖南厦门网站优化深圳建站公司
  • 外包网站怎么做seo如何设计一个网站页面
  • 独立域名网站建设网站seo的优化怎么做
  • 个人电商网站建设范例凡科建站怎么样
  • 郑州网站推广方法如何推广好一个产品
  • 淘宝客做网站好还是建群号网络推广工作怎么样
  • 男女直接做网站电子技术培训机构
  • 公司名称变更网站要重新备案检测网站是否安全
  • 石家庄住房建设厅网站金戈枸橼酸西地那非
  • wordpress外贸建站教程网络营销软件推广
  • 镇江手机网站建设网站排行榜查询
  • 网站开发用c 语言seo优化标题 关键词
  • 做网站外包需要提供什么百度seo推广计划类型包含
  • 快速装修公司seo推广怎么学
  • 福建金融公司网站建设百度竞价开户联系方式
  • 单页网站cpa虚拟主机5g站长工具seo综合查询
  • 数码网站建设总体目标蜘蛛seo超级外链工具
  • 可以免费打广告的平台网站排名优化多少钱
  • 东莞阿里巴巴网站建设安装百度到手机桌面
  • 龙岗附近做网站公司seo博客
  • 深圳网站建设网站运营2345网址导航浏览器
  • 莘县建设局网站如何快速提升网站关键词排名