今天就跟大家聊聊有关怎么返回python二叉树的中序遍历,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。
创新互联建站专注于宝丰企业网站建设,响应式网站设计,购物星空体育app最新版本(2024已更新)建设。宝丰网站建设公司,为宝丰等地区提供建站服务。全流程按需定制制作,专业设计,全程项目跟踪,创新互联建站专业和态度为您提供的服务
1.给定一个二叉树,返回它的中序 遍历。
2,示例
示例:
输入: [1,null,2,3]
1
\
2
/
3
输出: [1,3,2]
进阶: 递归算法很简单,你可以通过迭代算法完成吗?
3,题解思路
这里给出两种方式进行解决,一个是使用递归的方式进行解决,一个是使用迭代的方式进行
4,题解程序
import java.util.ArrayList;
import java.util.List;
import java.util.Stack;
public class InorderTraversalTest2 {
public static void main(String[] args) {
TreeNode t1 = new TreeNode(1);
TreeNode t2 = new TreeNode(2);
TreeNode t3 = new TreeNode(3);
t1.right = t2;
t2.left = t3;
List<Integer> list = inorderTraversal2(t1);
System.out.println("list = " + list);
}
private static List<Integer> list = new ArrayList<>();
public static List<Integer> inorderTraversal(TreeNode root) {
if (root == null) {
return list;
}
dfs(root);
return list;
}
private static void dfs(TreeNode root) {
if (root.left != null) {
dfs(root.left);
}
list.add(root.val);
if (root.right != null) {
dfs(root.right);
}
}
public static List<Integer> inorderTraversal2(TreeNode root) {
if (root == null) {
return list;
}
Stack<TreeNode> stack = new Stack<>();
TreeNode tempNode = root;
while (!stack.isEmpty() || tempNode != null) {
while (tempNode != null) {
stack.push(tempNode);
tempNode = tempNode.left;
}
TreeNode temp = stack.pop();
list.add(temp.val);
tempNode = temp.right;
}
return list;
}
}
5,题解程序图片版
根据二叉树的特点进行来做就可以了,利用递归的方式比使用迭代的方式在时间消耗上快了很多,递归的使用时利用了系统栈的方式去写,迭代的方式是使用自己创建的栈结构进行。
看完上述内容,你们对怎么返回python二叉树的中序遍历有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注创新互联行业资讯频道,感谢大家的支持。
网站标题:怎么返回python二叉树的中序遍历
本文路径:/article30/ishjso.html
成都网站建设公司_创新互联,为您提供动态网站、定制开发、ChatGPT、企业网站制作、、网站排名
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联