C#数组转二叉树

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace Algorithm {
	class TreeNode {
	     public int val;
	     public TreeNode left;
	     public TreeNode right;
	     public TreeNode(int x) { val = x; }
	 }
	class Tree {
		public static TreeNode CreateNode(int? val) {
			if (val == null) return null;
			return new TreeNode((int)val);
		}
		public static TreeNode CreateTree(int?[] arr) {
			if (arr.Length <= 0 || arr[0] == null) {
				return null;
			}
			TreeNode root = Tree.CreateNode(arr[0]);
			Queue<TreeNode> queue = new Queue<TreeNode>();
			queue.Enqueue(root);
			int index = 1;
			while (queue.Count > 0) {
				TreeNode node = queue.Dequeue();
				if (node == null) continue;
				if (index < arr.Length) {
					node.left = Tree.CreateNode(arr[index++]);
					queue.Enqueue(node.left);
				}
				if (index < arr.Length) {
					node.right = Tree.CreateNode(arr[index++]);
					queue.Enqueue(node.right);
				}
			}
			return root;
		}
		public static void Walk(TreeNode node, Action<TreeNode> func, TreeWalkType type) {
			if (node != null) {
				if (type == TreeWalkType.Pre) func(node);
				Walk(node.left, func, type);
				if (type == TreeWalkType.In) func(node);
				Walk(node.right, func, type);
				if (type == TreeWalkType.Post) func(node);
			}
		}
		//非递归,广度优先遍历
		public static void BFSWalk(TreeNode root, Action<TreeNode> func) {
			if (root == null) return;
			Queue<TreeNode> queue = new Queue<TreeNode>();
			queue.Enqueue(root);
			while (queue.Count > 0) {
				TreeNode node = queue.Dequeue();
				func(node);
				if (node.left != null) queue.Enqueue(node.left);
				if (node.right != null) queue.Enqueue(node.right);
			}
		}
		//非递归,中序遍历
		public static void InOrderTreeWalk(TreeNode root, Action<TreeNode> func) {
			if (root == null) {
				return;
			}
			Stack<TreeNode> stack = new Stack<TreeNode>();
			TreeNode current = root;
			while (current != null) {
				stack.Push(current);
				current = current.left;
			}
			while (stack.Count != 0) {
				current = stack.Pop();
				func(current);             //func
				TreeNode node = current.right;
				while (node != null) {
					stack.Push(node);
					node = node.left;
				}
			}
		}
	}
	enum TreeWalkType {
		Pre,
		In,
		Post
	}
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值