• 手机版

    扫码体验手机版

  • 微信公众号

    扫码关注公众号

国内首家协议开发

软芯音视解码保护平台

在线
客服

发布
需求

在线
聊天

天盟
APP

天盟APP下载

关注
微信

微信扫一扫访问
顶部

剑指offer:二叉树的镜像 为什么我的while循环成了死循环呢?

书中的举例如下:


我写的代码是:
/**public class TreeNode {    int val = 0;    TreeNode left = null;    TreeNode right = null;    public TreeNode(int val) {        this.val = val;    }}*/public class Solution {    public void Mirror(TreeNode root) {        while(root.left!=null||root.right!=null){            TreeNode rootLeft = root.left;            TreeNode rootRight = root.right;            root.left = rootRight;            root.right = rootLeft;            while(root.left!=null){                    System.out.println(root.left.val);                Mirror(root.left);            }            while(root.right!=null){                    System.out.println(root.right.val);                Mirror(root.right);            }        }    }}结果一直输出11 跳不出循环 请问是为什么呢?

免责声明:本内容仅代表回答会员见解不代表天盟观点,请谨慎对待。

版权声明:作者保留权利,不代表天盟立场。

使用道具 举报

全部参与1

while(root.left!=null||root.right!=null){这句话是死循环啊,因为判断条件永远为真啊

既然用了递归,就不需要再递归里面再循环了,把所有的while换成if就行了

使用道具 举报

发新帖

发布任务需求已有1031164位用户正在使用天盟网服务

发布分类: *
任务预算: *
需求内容: *
手机号码: *
任务商家报价为
  • 预算价 :
  • 成交价 :
  • 完工期 :
  • 质保期 :

* 最终任务项目以服务商报价、双方协商为准!