题解 | #二叉树的中序遍历#

二叉树的中序遍历

http://www.nowcoder.com/practice/0bf071c135e64ee2a027783b80bf781d

import java.util.*;

/*

  • public class TreeNode {
  • int val = 0;
  • TreeNode left = null;
  • TreeNode right = null;
  • public TreeNode(int val) {
  • this.val = val;
    
  • }
  • } */

public class Solution { /** * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * * 二叉树的中序遍历 * * @param root TreeNode类 * @return int整型一维数组 */

public int[] inorderTraversal (TreeNode root) {
    // write code here
    //特殊值处理
    if(root == null){
        return new int[0];
    }
    ArrayList<Integer> arrayList = new ArrayList<>();//创建一个链表
    order(root,arrayList);//中根遍历
    Object[] obj = arrayList.toArray();//链表转换为Object数组
    int length = obj.length;
    int[] arr = new int[length];
    //Object数组转换为整形数组
    for(int i=0;i<length;i++){
        arr[i] = (int)obj[i];
    }
    
    return arr;
}

public void order(TreeNode root,ArrayList<Integer> arrayList){
    //递归出口
    if(root == null){
        return ;
    }
    
    order(root.left,arrayList);//遍历左子树
    arrayList.add(root.val);//遍历根
    order(root.right,arrayList);//遍历右子树
}

}

全部评论

相关推荐

故事和酒66:央企,事少钱少稳定福利好,离家近可以考虑
点赞 评论 收藏
分享
09-13 08:41
服装/纺织设计
那一天的Java_J...:你第一次参加面试吗
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务