乐趣区

关于二叉树:二叉树遍历中序遍历Golang

简介

中序遍历(LDR)是二叉树遍历的一种,也叫做中根遍历、中序环游。

定义

在二叉树中,中序遍历首先遍历左子树,而后拜访根结点,最初遍历右子树。若二叉树为空则完结返回,否则:(1)中序遍历左子树(2)拜访根结点(3)中序遍历右子树

如图所示二叉树,中序遍历后果:DBEAFC

Golang 实现

func (root *TreeNode) inorder()[]int{res:=[]int{}
    if root==nil{return res}
    stack:=[]*TreeNode{}
    for root!=nil || len(stack)!=0{
        if root!=nil{stack=append(stack,root)
            root=root.Lchild
        }else{root=stack[len(stack)-1]
            res=append(res,root.data)
            stack=stack[:len(stack)-1]
            root=root.Rchild
        }
    }
    return res
}
退出移动版