树状打印二叉树的类Java、Go、PHP

本文详细介绍了在Java、Go和PHP三种编程语言中实现的树状二叉树的层次遍历方法,展示了如何计算树的深度以及递归打印树的结构。
摘要由CSDN通过智能技术生成

说明和效果

   树的结构示例:
             1
           /   \
         2       3
        / \     / \
       4   5   6   7

树状打印二叉树Java代码

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


   //打印二叉树的类
    // TreeOperation.java
    static class TreeNodeShow {
    /*
    树的结构示例:
              1
            /   \
          2       3
         / \     / \
        4   5   6   7
    */

    // 用于获得树的层数
    public static int getTreeDepth(TreeNode root) {
        return root == null ? 0 : (1 + Math.max(getTreeDepth(root.left), getTreeDepth(root.right)));
    }


    private static void writeArray(TreeNode currNode, int rowIndex, int columnIndex, String[][] res, int treeDepth) {
        // 保证输入的树不为空
        if (currNode == null) return;
        // 先将当前节点保存到二维数组中
        res[rowIndex][columnIndex] = String.valueOf(currNode.val);

        // 计算当前位于树的第几层
        int currLevel = ((rowIndex + 1) / 2);
        // 若到了最后一层,则返回
        if (currLevel == treeDepth) return;
        // 计算当前行到下一行,每个元素之间的间隔(下一行的列索引与当前元素的列索引之间的间隔)
        int gap = treeDepth - currLevel - 1;

        // 对左儿子进行判断,若有左儿子,则记录相应的"/"与左儿子的值
        if (currNode.left != null) {
            res[rowIndex + 1][columnIndex - gap] = "/";
            writeArray(currNode.left, rowIndex + 2, columnIndex - gap * 2, res, treeDepth);
        }

        // 对右儿子进行判断,若有右儿子,则记录相应的"\"与右儿子的值
        if (currNode.right != null) {
            res[rowIndex + 1][columnIndex + gap] = "\\";
            writeArray(currNode.right, rowIndex + 2, columnIndex + gap * 2, res, treeDepth);
        }
    }


    public static void show(TreeNode root) {
        if (root == null) System.out.println("EMPTY!");
        // 得到树的深度
        int treeDepth = getTreeDepth(root);

        // 最后一行的宽度为2的(n - 1)次方乘3,再加1
        // 作为整个二维数组的宽度
        int arrayHeight = treeDepth * 2 - 1;
        int arrayWidth = (2 << (treeDepth - 2)) * 3 + 1;
        // 用一个字符串数组来存储每个位置应显示的元素
        String[][] res = new String[arrayHeight][arrayWidth];
        // 对数组进行初始化,默认为一个空格
        for (int i = 0; i < arrayHeight; i++) {
            for (int j = 0; j < arrayWidth; j++) {
                res[i][j] = " ";
            }
        }

        // 从根节点开始,递归处理整个树
        // res[0][(arrayWidth + 1)/ 2] = (char)(root.val + '0');
        writeArray(root, 0, arrayWidth / 2, res, treeDepth);

        // 此时,已经将所有需要显示的元素储存到了二维数组中,将其拼接并打印即可
        for (String[] line : res) {
            StringBuilder sb = new StringBuilder();
            for (int i = 0; i < line.length; i++) {
                sb.append(line[i]);
                if (line[i].length() > 1 && i <= line.length - 1) {
                    i += line[i].length() > 4 ? 2 : line[i].length() - 1;
                }
            }
            System.out.println(sb.toString());
        }
    }
}

使用例子:
TreeNodeShow.show(new TreeNode(1));

树状打印二叉树Go代码

type TreeNode struct {
	Val   int
	Left  *TreeNode
	Right *TreeNode
}

//打印二叉树的类
// TreeOperation.java

type TreeNodeShow struct {
}

func (ts TreeNodeShow) getTreeDepth(root *TreeNode) int {
	if root == nil {
		return 0
	}
	L := ts.getTreeDepth(root.Left)
	R := ts.getTreeDepth(root.Right)

	ans := L
	if ans < R {
		ans = R
	}

	return ans + 1
}

func (ts TreeNodeShow) writeArray(currNode *TreeNode, rowIndex int, columnIndex int,
 res [][]string, treeDepth int) {
	// 保证输入的树不为空
	if currNode == nil {
		return
	}
	// 先将当前节点保存到二维数组中
	res[rowIndex][columnIndex] = strconv.Itoa(currNode.Val)

	// 计算当前位于树的第几层
	currLevel := ((rowIndex + 1) / 2)
	// 若到了最后一层,则返回
	if currLevel == treeDepth {
		return
	}
	// 计算当前行到下一行,每个元素之间的间隔(下一行的列索引与当前元素的列索引之间的间隔)
	gap := treeDepth - currLevel - 1

	// 对左儿子进行判断,若有左儿子,则记录相应的"/"与左儿子的值
	if currNode.Left != nil {
		res[rowIndex+1][columnIndex-gap] = "/"
		ts.writeArray(currNode.Left, rowIndex+2, columnIndex-gap*2, res, treeDepth)
	}

	// 对右儿子进行判断,若有右儿子,则记录相应的"\"与右儿子的值
	if currNode.Right != nil {
		res[rowIndex+1][columnIndex+gap] = "\\"
		ts.writeArray(currNode.Right, rowIndex+2, columnIndex+gap*2, res, treeDepth)
	}
}

func (ts TreeNodeShow) show(root *TreeNode) {
	if root == nil {
		fmt.Println("EMPTY!")
	}
	// 得到树的深度
	treeDepth := ts.getTreeDepth(root)

	// 最后一行的宽度为2的(n - 1)次方乘3,再加1
	// 作为整个二维数组的宽度
	arrayHeight := treeDepth*2 - 1
	arrayWidth := (2<<(treeDepth-2))*3 + 1
	// 用一个字符串数组来存储每个位置应显示的元素
	res := make([][]string, arrayHeight)
	for x := 0; x < arrayHeight; x++ {
		res[x] = make([]string, arrayWidth)
	}
	// 对数组进行初始化,默认为一个空格
	for i := 0; i < arrayHeight; i++ {
		for j := 0; j < arrayWidth; j++ {
			res[i][j] = " "
		}
	}

	// 从根节点开始,递归处理整个树
	// res[0][(arrayWidth + 1)/ 2] = (char)(root.val + '0');
	ts.writeArray(root, 0, arrayWidth/2, res, treeDepth)

	// 此时,已经将所有需要显示的元素储存到了二维数组中,将其拼接并打印即可
	//for (String[] line : res) {
	for _, line := range res {
		sb := ""
		for i := 0; i < len(line); i++ {
			sb = sb + line[i]
			if len(line[i]) > 1 && i <= len(line)-1 {
				//i += line[i].length() > 4 ? 2 : line[i].length() - 1;
				if len(line[i]) > 4 {
					i = i + 2
				} else {
					i = len(line[i]) - 1
				}
				//i =i+ len(line[i]) > 4 ? 2 : len(line[i]) - 1;
			}
		}

		fmt.Println(sb)
	}

}

使用:

TreeNodeShow.show(new TreeNode(1));

使用

node1 := TreeNode{1, nil, nil}
node1.Left = &TreeNode{2, nil, nil}
node1.Left.Left = &TreeNode{3, nil, nil}

node1.Right = &TreeNode{5, nil, nil}
node1.Right.Left = &TreeNode{4, nil, nil}
node1.Right.Right = &TreeNode{6, nil, nil}
ts := TreeNodeShow{}
ts.show(&node1)

树状打印二叉树PHP代码

   class TreeNode{
    var $val;
    var $left = NULL;
    var $right = NULL;
    function __construct($val){
        $this->val = $val;
    }
}



//PHP打印二叉树的类
// TreeOperation.java
class TreeNodeShow {
    /*
    树的结构示例:
              1
            /   \
          2       3
         / \     / \
        4   5   6   7
    */

    // 用于获得树的层数
    public static function getTreeDepth($root) {
        if($root ==null) return 0;
            $deepLeft = self::getTreeDepth($root->left);
            $deepRight = self::getTreeDepth($root->right);
            $max = $deepLeft;
            if($max < $deepRight){
                $max = $deepRight;
            }
            return  1 + $max;
        }

        private static function writeArray($currNode, $rowIndex, $columnIndex, &$res, $treeDepth) {
    // 保证输入的树不为空
    if ($currNode == null) return;
    // 先将当前节点保存到二维数组中
    $res[$rowIndex][$columnIndex] = $currNode->val;

    // 计算当前位于树的第几层
    $currLevel = intval(($rowIndex + 1) / 2);
            // 若到了最后一层,则返回
            if ($currLevel == $treeDepth) return;
            // 计算当前行到下一行,每个元素之间的间隔(下一行的列索引与当前元素的列索引之间的间隔)
            $gap = $treeDepth - $currLevel - 1;

            // 对左儿子进行判断,若有左儿子,则记录相应的"/"与左儿子的值
            if ($currNode ->left != null) {
                $res[$rowIndex + 1][$columnIndex - $gap] = "/";
                self::  writeArray($currNode -> left, $rowIndex + 2, $columnIndex - $gap * 2, $res, $treeDepth);
            }

            // 对右儿子进行判断,若有右儿子,则记录相应的"\"与右儿子的值
            if ($currNode -> right != null) {
                $res[$rowIndex + 1][$columnIndex + $gap] = "\\";
                self::writeArray($currNode->right, $rowIndex + 2, $columnIndex + $gap * 2, $res, $treeDepth);
            }
        }


        public static function show($root) {
    if ($root == null) echo "EMPTY!".PHP_EOL;
    // 得到树的深度
    $treeDepth = self:: getTreeDepth($root);

            // 最后一行的宽度为2的(n - 1)次方乘3,再加1
            // 作为整个二维数组的宽度
            $arrayHeight = $treeDepth * 2 - 1;
            $arrayWidth = (2 << ($treeDepth - 2)) * 3 + 1;
            // 用一个字符串数组来存储每个位置应显示的元素
            $res = array();
            // 对数组进行初始化,默认为一个空格
            for ($i = 0; $i < $arrayHeight; $i++) {
        for ($j = 0; $j < $arrayWidth; $j++) {
            $res[$i][$j] = " ";
        }
            }

            // 从根节点开始,递归处理整个树
            // res[0][(arrayWidth + 1)/ 2] = (char)(root.val + '0');
            self:: writeArray($root, 0, intval($arrayWidth / 2), $res, $treeDepth);

            // 此时,已经将所有需要显示的元素储存到了二维数组中,将其拼接并打印即可
            /*
             *  for (String[] line : res) {
                StringBuilder sb = new StringBuilder();
                for (int i = 0; i < line.length; i++) {
                    sb.append(line[i]);
                    if (line[i].length() > 1 && i <= line.length - 1) {
                        i += line[i].length() > 4 ? 2 : line[i].length() - 1;
                    }
                }
                System.out.println(sb.toString());
            }
             */
            for ($x=0;$x<count($res);$x++ ) {
                $sb = '';
                $line = $res[$x];
                if(gettype($line) =='NULL') continue;
                if(gettype($line) ==NULL) continue;
                //var_dump('长度:'.count($line).'  类型:'.(gettype($line)));
                for ($i = 0; $i < count($line); $i++) {
                    $sb.=$line[$i];
                    if (strlen($line[$i]) > 1 && $i <= count($line) - 1) {
                        $i .= strlen($line[$i]) > 4 ? 2 : strlen($line[$i]) - 1;
                    }
                }
                echo $sb.PHP_EOL;
            }
        }
    }




使用:
$node1 = new TreeNode(1);
$node1->left = new TreeNode(2);
$node1->left->left = new TreeNode(3);
$node1->right = new TreeNode(5);
$node1->right->left= new TreeNode(4);
$node1->right->right= new TreeNode(6);


TreeNodeShow::show($node1);
  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
下面是二叉树打印Java代码实现: ``` public class BinaryTreePrinter { public static void printNode(TreeNode root) { int maxLevel = maxLevel(root); printNodeInternal(Collections.singletonList(root), 1, maxLevel); } private static void printNodeInternal(List<TreeNode> nodes, int level, int maxLevel) { if (nodes.isEmpty() || isAllElementsNull(nodes)) return; int floor = maxLevel - level; int edgeLines = (int) Math.pow(2, (Math.max(floor - 1, 0))); int firstSpaces = (int) Math.pow(2, (floor)) - 1; int betweenSpaces = (int) Math.pow(2, (floor + 1)) - 1; printWhitespaces(firstSpaces); List<TreeNode> newNodes = new ArrayList<>(); for (TreeNode node : nodes) { if (node != null) { System.out.print(node.val); newNodes.add(node.left); newNodes.add(node.right); } else { newNodes.add(null); newNodes.add(null); System.out.print(" "); } printWhitespaces(betweenSpaces); } System.out.println(""); for (int i = 1; i <= edgeLines; i++) { for (int j = 0; j < nodes.size(); j++) { printWhitespaces(firstSpaces - i); if (nodes.get(j) == null) { printWhitespaces(edgeLines + edgeLines + i + 1); continue; } if (nodes.get(j).left != null) System.out.print("/"); else printWhitespaces(1); printWhitespaces(i + i - 1); if (nodes.get(j).right != null) System.out.print("\\"); else printWhitespaces(1); printWhitespaces(edgeLines + edgeLines - i); } System.out.println(""); } printNodeInternal(newNodes, level + 1, maxLevel); } private static void printWhitespaces(int count) { for (int i = 0; i < count; i++) System.out.print(" "); } private static int maxLevel(TreeNode node) { if (node == null) return 0; return Math.max(maxLevel(node.left), maxLevel(node.right)) + 1; } private static boolean isAllElementsNull(List list) { for (Object object : list) { if (object != null) return false; } return true; } public static void main(String[] args) { TreeNode root = new TreeNode(1); root.left = new TreeNode(2); root.right = new TreeNode(3); root.left.left = new TreeNode(4); root.left.right = new TreeNode(5); root.right.left = new TreeNode(6); root.right.right = new TreeNode(7); printNode(root); } } class TreeNode { int val; TreeNode left; TreeNode right; TreeNode(int x) { val = x; } } ``` 通过调用`printNode`方法,可以打印二叉树形结构。其中`TreeNode`表示二叉树节点,`val`表示节点的值,`left`和`right`分别表示节点的左右子节点。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

赵长辉

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值