Swift-二叉树创建

题目:根据二叉树的先序遍历结果构建二叉树.

树.jpg

创建二叉树
<pre><code>` func createTreeByPreOrder(root:inout TreeNode?,listData:[String]) {

    rootIndex = rootIndex + 1
    
    if rootIndex >= listData.count {
        return
    }
    
    let data:String = listData[rootIndex] as String
    
    if data == "#" {
        root = nil
    } else {
        root = TreeNode()
        root?.data = data
        createTreeByPreOrder(root: &root!.leftChild, listData: listData)
        createTreeByPreOrder(root: &root!.rightChild, listData: listData)
    }
    
}`</code></pre>

层次遍历二叉树
<pre><code>` func treeLevelOrder(root:TreeNode?) {

    if root == nil {
        return
    }
    
    var arr:[TreeNode] = []
    arr.append(root!)
    
    while arr.count > 0 {
        
        let firstNode:TreeNode = arr[0]
        
        if firstNode.data != nil {
            print("\(firstNode.data!)\t", terminator: "")
            arr.removeFirst()
        }
        
        
        if firstNode.leftChild != nil {
            arr.append(firstNode.leftChild!)
        }
        
        
        if firstNode.rightChild != nil {
            arr.append(firstNode.rightChild!)
        }

    }
    
    print("")
}`</code></pre>

测试代码:
<pre><code>`var tree:Tree = Tree()
var preListData:[String] = ["1","2","4","#","#","5","7","#","#","#","3","#","6","#","#"]
var preOrderRoot:TreeNode?

tree.createTreeByPreOrder(root: &preOrderRoot, listData: preListData)
tree.treeLevelOrder(root: preOrderRoot)
print("FlyElephant")`</code></pre>

FlyElephant.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 树的概述 树是一种非常常用的数据结构,树与前面介绍的线性表,栈,队列等线性结构不同,树是一种非线性结构 1.树的定...
    Jack921阅读 4,501评论 1 31
  • 二叉查找树(Binary Sort Tree) 我们之前所学到的列表,栈等都是一种线性的数据结构,今天我们将学习计...
    Cryptic阅读 5,042评论 1 19
  • 去年二叉树算法的事情闹的沸沸扬扬,起因是Homebrew 的作者 @Max Howell 在 twitter 上发...
    Masazumi柒阅读 1,629评论 0 8
  • 这几天开学,学校还在上课,最近也是在找工作,很多天都没有更新文章,现在补一篇二叉树的文章。 最近校招公司的笔试陆续...
    zero_sr阅读 3,998评论 0 5
  • 本文参加#未完待续,就要表白#活动,本人承诺,文章内容为原创,且未在其他平台发表过。 丁酉年贺山大校庆文 晋阳故郡...
    耳月阅读 338评论 0 0