二叉树遍历OJ题
描述
编一个程序,读入用户输入的一串先序遍历字符串,根据此字符串建立一个二叉树(以指针方式存储)。 例如如下的先序遍历字符串: ABC##DE#G##F### 其中“#”表示的是空格,空格字符代表空树。建立起此二叉树以后,再对二叉树进行中序遍历,输出遍历结果。
输入描述:
输入包括1行字符串,长度不超过100。
输出描述:
可能有多组测试数据,对于每组数据, 输出将输入字符串建立二叉树后中序遍历的序列,每个字符后面都有一个空格。 每个输出结果占一行。
示例1
输入:abc##de#g##f###
复制输出:c b e g d f a
需求:
1.读入字符串
2.构建先序遍历字符串
3.中序遍历输出字符串
需要解决的问题
1.如何从键盘读取字符串
2.如何通过字符串构建二叉树
3.如何中序遍历,逐个输出字符串
1.如何从键盘读取字符串
Scanner scan = new Scanner(System.in);
while(scan.hasNextLine()) {
String str = scan.nextLine();
TreeNode root = createTree(str);
2.如何通过字符串构建二叉树
(1)字符串里取字符
str.charAt(i) 的意思是,取字符串str中第i位的字符
str.charAt(i) != '#'
(2)新建一个树的节点root来接收字符
root = new TreeNode(str.charAt(i));
(3)root开始前序遍历(根——左——右)每接收一位字符,就要i++,才能取后面的字符
public static int i = 0; //i的作用是确定字符串的第几位。
public static TreeNode createTree(String str) {
TreeNode root = null;
if(str.charAt(i) != '#'){
root = new TreeNode(str.charAt(i)); //root 新建一个节点,值为str.charAt(i)的值
i++;
root.left = createTree(str);
root.right = createTree(str);
}else{
i++;
}return root;
}
3.如何中序遍历输出字符串
public static void inOrderTraversal(TreeNode root) {
if(root == null) return;
inOrderTraversal(root.left);
System.out.print(root.val+" ");
inOrderTraversal(root.right);
}
整段代码
import java.util.*;
class TreeNode { //二叉树都要先定义一个TreeNode的类
public char val;
public TreeNode left;
public TreeNode right;
public TreeNode(char val) {
this.val = val;
}
}
public class Main {
public static int i = 0; //必须储存再静态区
public static TreeNode createTree(String str) {
TreeNode root = null;
if(str.charAt(i) != '#'){
root = new TreeNode(str.charAt(i));
i++;
root.left = createTree(str);
root.right = createTree(str);
}else{
i++; //如果遇到'#',只需要i++即可
}return root; //返回节点的值
}
/*中序遍历打印*/
public static void inOrderTraversal(TreeNode root) {
if(root == null) return;
inOrderTraversal(root.left);
System.out.print(root.val+" ");
inOrderTraversal(root.right);
}
/*先输入字符串,再构建前序遍历的二叉树,再通过中序遍历打印出二叉树*/
public static void main(String[] args) {
Scanner scan = new Scanner(System.in); //主函数的过程与思考过程一致
while(scan.hasNextLine()) {
String str = scan.nextLine();
TreeNode root = createTree(str);
inOrderTraversal(root);
}
}
}