zoukankan      html  css  js  c++  java
  • Golang实现数的几种遍历

    PreOrder

    recursive

    package main
    
    import "fmt"
    
    type TreeNode struct {
    	val   int
    	Left  *TreeNode
    	Right *TreeNode
    }
    
    func preorderTraversal(root *TreeNode) {
    	if root == nil {
    		return
    	}
    	fmt.Println(root.val)
    	preorderTraversal(root.Left)
    	preorderTraversal(root.Right)
    }
    
    func main() {
    	/*
                                10
                               /  
                             20    30
                            /       
                          40  50     60
    		      /
    		     70
    	*/
    
    	root := &TreeNode{10, nil, nil}
    	root.Left = &TreeNode{20, nil, nil}
    	root.Right = &TreeNode{30, nil, nil}
    	root.Left.Left = &TreeNode{40, nil, nil}
    	root.Left.Right = &TreeNode{50, nil, nil}
    	root.Right.Right = &TreeNode{60, nil, nil}
    	root.Left.Left.Left = &TreeNode{70, nil, nil}
    
    	fmt.Println("Preorder Traversal - Recursive Solution : ")
    	preorderTraversal(root)
    }
    
    

    Iterative

    package main
    
    import "fmt"
    
    type TreeNode struct {
    	val   int
    	Left  *TreeNode
    	Right *TreeNode
    }
    
    func preorderTraversal(root *TreeNode) {
    	if root == nil {
    		return
    	}
    	stack := make([]*TreeNode, 0)
    
    	for root != nil || len(stack) != 0 {
    		for root != nil {
    			fmt.Println(root.val)
    			stack = append(stack, root)
    			root = root.Left
    		}
    		v := stack[len(stack)-1]
    		stack = stack[:len(stack)-1]
    		root = v.Right
    	}
    }
    
    func main() {
    	/*
                                10
                               /  
                             20    30
                            /       
                          40  50     60
    		      /
    		     70
    	*/
    
    	root := &TreeNode{10, nil, nil}
    	root.Left = &TreeNode{20, nil, nil}
    	root.Right = &TreeNode{30, nil, nil}
    	root.Left.Left = &TreeNode{40, nil, nil}
    	root.Left.Right = &TreeNode{50, nil, nil}
    	root.Right.Right = &TreeNode{60, nil, nil}
    	root.Left.Left.Left = &TreeNode{70, nil, nil}
    
    	fmt.Println("Preorder Traversal - Iterative Solution : ")
    	preorderTraversal(root)
    }
    
    

    另一种写法

    func preorderTraversal(root *TreeNode) {
    	if root == nil {
    		return
    	}
    	stack := make([]*TreeNode, 0)
    	stack = append(stack, root)
    
    	for len(stack) != 0 {
    		node := stack[len(stack)-1]
    		stack = stack[:len(stack)-1]
    		fmt.Println(node.val)
    
    		if node.Right != nil {
    			stack = append(stack, node.Right)
    		}
    		if node.Left != nil {
    			stack = append(stack, node.Left)
    		}
    	}
    }
    

    InOrder

    Iterative

    func inorderTraverse(root *TreeNode) {
    	if root == nil {
    		return
    	}
    	stack := make([]*TreeNode, 0)
    
    	for root != nil || len(stack) != 0 {
    		for root != nil {
    			stack = append(stack, root)
    			root = root.Left
    		}
    		node := stack[len(stack)-1]
    		stack = stack[:len(stack)-1]
    		fmt.Println(node.val)
    		root = node.Right
    	}
    }
    

    PostOrder

    Iterative

    func postorderTraversal(root *TreeNode) {
    	if root == nil {
    		return
    	}
    	stack := make([]*TreeNode, 0)
    	var lastNode *TreeNode
    
    	for root != nil || len(stack) != 0 {
    		for root != nil {
    			stack = append(stack, root)
    			root = root.Left
    		}
    		node := stack[len(stack)-1]
    		if node.Right == nil || node.Right == lastNode {
    			stack = stack[:len(stack)-1]
    			lastNode = node
    			fmt.Println(node.val)
    		} else {
    			root = node.Right
    		}
    	}
    }
    
  • 相关阅读:
    Hive分桶bucket
    Error: java.io.IOException: org.apache.hadoop.hdfs.BlockMissingException: Could not obtain block
    接上一篇嵌套循环问题之解决
    RPA自动化机器人uibot之循环嵌套坑
    Chrom谷歌浏览器没网之最全解决办法之一
    (语法糖)列表生成式之怪诞--(暂时无法理解)
    浅析scrapy与scrapy-redis的区别
    浅谈Python中函数式编程、面向对象编程以及古怪的PythonIC
    OpenCV+TensorFlow图片手写数字识别(附源码)
    TensorFlow Object Detection API中的Faster R-CNN /SSD模型参数调整
  • 原文地址:https://www.cnblogs.com/pusidun/p/13127355.html
Copyright © 2011-2022 走看看