ACM模式数组构建二叉树Go语言实现

目的

想输入一个数组,然后构造二叉树

例如数组为[6, 2, 8, 0, 4, 7, 9, -1, -1, 3, 5]

对应的二叉树为:

参考资料

ACM模式数组构建二叉树

重点:如果父节点的数组下标是i,那么它的左孩子下标就是i*2+1,右孩子下标就是i*2+2

go代码实现

go 复制代码
package main

import "fmt"

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

// 根据数组构造二叉树
func constructBinaryTree(nums []int) *TreeNode {
	treenode := make([]*TreeNode, len(nums))
	for i := 0; i < len(nums); i++ {
		var node *TreeNode //如果等于-1的话就是nil
		if nums[i] != -1 {
			node = &TreeNode{Val: nums[i]}
			treenode[i] = node
		}
	}
	for i := 0; i*2+2 < len(nums); i++ {
		if treenode[i] != nil {
			treenode[i].Left = treenode[i*2+1]
			treenode[i].Right = treenode[i*2+2]
		}
	}
	return treenode[0] //root=treenode[0]
}

// 前序遍历-用于验证
func preorderTraversal(root *TreeNode) (res []int) {
	var traversal func(node *TreeNode)
	traversal = func(node *TreeNode) {
		if node == nil {
			return
		}
		res = append(res, node.Val)
		traversal(node.Left)
		traversal(node.Right)
	}
	traversal(root)
	return res
}

// 中序遍历-用于验证
func inorderTraversal(root *TreeNode) (res []int) {
	var traversal func(node *TreeNode)
	traversal = func(node *TreeNode) {
		if node == nil {
			return
		}
		traversal(node.Left)
		res = append(res, node.Val)
		traversal(node.Right)
	}
	traversal(root)
	return res
}

// 后序遍历-用于验证
func postorderTraversal(root *TreeNode) (res []int) {
	var traversal func(node *TreeNode)
	traversal = func(node *TreeNode) {
		if node == nil {
			return
		}
		traversal(node.Left)
		traversal(node.Right)
		res = append(res, node.Val)
	}
	traversal(root)
	return res
}

func main() {
	nums := []int{6, 2, 8, 0, 4, 7, 9, -1, -1, 3, 5}
	root := constructBinaryTree(nums)
	fmt.Println("前序遍历:", preorderTraversal(root))
	fmt.Println("中序遍历:", inorderTraversal(root))
	fmt.Println("后序遍历:", postorderTraversal(root))
}

输出:

复制代码
前序遍历: [6 2 0 4 3 5 8 7 9]
中序遍历: [0 2 3 4 5 6 7 8 9] 
后序遍历: [0 3 5 4 2 7 9 8 6] 
相关推荐
n8n3 小时前
Go语言GC调优全面指南
go
n8n3 小时前
Go 协程在实际项目中的应用详解
go
苏琢玉4 小时前
再也不用翻一堆日志!一键部署轻量级错误监控系统,帮你统一管理 PHP 报错
go·github·php
程序员爱钓鱼6 小时前
Go语言实战案例——进阶与部署篇:使用Docker部署Go服务
后端·google·go
程序员爱钓鱼18 小时前
Go语言实战案例——进阶与部署篇:编写Makefile自动构建Go项目
后端·算法·go
该用户已不存在19 小时前
别再用 if err != nil 了,学会这几个技巧,假装自己是Go大神
后端·go
n8n21 小时前
Go语言操作Redis全面指南
go
王中阳Go1 天前
为什么很多公司都开始使用Go语言了?为啥这个话题这么炸裂?
java·后端·go
Sesame22 天前
gotun: 一个基于SSH协议的零配置HTTP代理工具
go
豆浆Whisky3 天前
Go泛型实战指南:从入门到工程最佳实践|Go语言进阶(12)
后端·go