一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Swift - Swift算法之二叉樹實現的方法示例

Swift算法之二叉樹實現的方法示例

2021-01-05 14:47李峰峰 Swift

二叉樹是計算機科學中最基本也是最重要的樹型結構,最常見的二叉樹生成算法通常是使用遞歸或者其他描述類語言的方法來實現。本文主要介紹了Swift算法之二叉樹實現的方法,文中介紹的非常詳細,對大家具有一定的參考價值,

一、概述

二叉樹的結構一般是以二叉鏈表的形式來存儲的。二叉鏈表的結構類似于雙向鏈表,二叉鏈表的節點也是有兩個結點指針的,一個指向左子樹,一個指向右子樹。二叉樹主要有四種遍歷方式:先序遍歷、中序遍歷、后序遍歷、層次遍歷。關于二叉樹的內容網上有很多,這里不再做過多的陳述。

本文將用Swift去實現二叉樹的創建、四種遍歷方式等。下面的實現部分內容參考了青玉伏案和唐巧兩位大神相關的文章。

二、實現思路及代碼

以下面二叉樹為例:

Swift算法之二叉樹實現的方法示例

先序遍歷:先遍歷根節點然后再遍歷左子樹,最后遍歷右子樹。

Swift算法之二叉樹實現的方法示例

故上面先序遍歷的順序為: A B D E C F

不過為了看到更詳細的步驟可以把上面 C 結點的左子節點的 value 值打印為#號,類似的D、E、F也一樣,他們的左右子節點的 value 值都打印為#號,則打印結果為:A B D # # E # # C # F # #

中序遍歷:先遍歷左子樹,然后遍歷根節點,最后遍歷右子樹。

Swift算法之二叉樹實現的方法示例

故上面先序遍歷的順序為:# D # B # E # A # C # F #

后序遍歷:后序遍歷是先遍歷左子樹,然后再遍歷右子樹,最后遍歷根節點

Swift算法之二叉樹實現的方法示例

故上面先序遍歷的順序為:# # D # # E B # # # F C A

層次遍歷:層次遍歷相對上面的幾個遍歷實現起來要稍微復雜,層次遍歷就是圖中以二叉樹的根節點為起始節點的廣度搜索(BFS)

Swift算法之二叉樹實現的方法示例

故上面先序遍歷的順序為:A B C D E # F # # # # # #

下面為上述幾種遍歷的Swift實現:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
class BinaryTreeNote{
 
 var value:String
 var leftChild:BinaryTreeNote?
 var rightChild:BinaryTreeNote?
 
 init(_ value:String) {
 self.value = value
 }
 
}
 
 
class BinaryTreeHelper{
 
 var array:[String]
 var index = -1
 
 init(_ array:[String]) {
 self.array = array
 }
 
 //創建二叉樹
 func createTree() -> BinaryTreeNote? {
 
 self.index = self.index + 1
 if index < self.array.count && index >= 0 {
 
  let value = self.array[index]
  
  if value == "" {
  return nil
  } else {
  let note = BinaryTreeNote(value)
  note.leftChild = createTree()
  note.rightChild = createTree()
  return note
  }
 }
 return nil;
 }
 
 //先序遍歷二叉樹
 func preOrderTraverse(_ note:BinaryTreeNote?){
 
 if note == nil {
  print("#")
  return
 }
 print(note!.value)
 preOrderTraverse(note!.leftChild)
 preOrderTraverse(note!.rightChild)
 }
 
 //中序遍歷二叉樹
 func inOrderTraverse (_ note: BinaryTreeNote?) {
 if note == nil {
  print("#")
  return
 }
 inOrderTraverse(note!.leftChild)
 print(note!.value)
 inOrderTraverse(note!.rightChild)
 }
 
 //后序遍歷二叉樹
 func afterOrderTraverse (_ note: BinaryTreeNote?) {
 if note == nil {
  print("#")
  return
 }
 afterOrderTraverse(note!.leftChild)
 afterOrderTraverse(note!.rightChild)
 print(note!.value)
 }
 
 //層次遍歷二叉樹
 func levelOrder(_ root: BinaryTreeNote?){
 
 var result = [[BinaryTreeNote]]()
 var level = [BinaryTreeNote]()
 
 level.append(root!)
 while level.count != 0 {
  result.append(level)
  var nextLevel = [BinaryTreeNote]()
  for node in level {
  if let leftNode = node.leftChild {
   nextLevel.append(leftNode)
  }
  if let rightNode = node.rightChild {
   nextLevel.append(rightNode)
  }
  }
  level = nextLevel
 }
 
 let ans = result.map { $0.map { $0.value }}
 print(ans)
 }
 
 
}

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者使用swift能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對服務器之家的支持。

原文鏈接:http://www.imlifengfeng.com/blog/?p=661

延伸 · 閱讀

精彩推薦
  • Swiftswift where與匹配模式的實例詳解

    swift where與匹配模式的實例詳解

    這篇文章主要介紹了swift where與匹配模式的實例詳解的相關資料,這里附有簡單的示例代碼,講的比較清楚,需要的朋友可以參考下...

    追到夢的魔術師14382021-01-06
  • SwiftSwift能代替Objective-C嗎?

    Swift能代替Objective-C嗎?

    這是我在網上上看到的答案,復制粘貼過來和大家分享一下,因為我和很多人一樣很關心Swift的出現對Mac開發的影響和對Objective-C的影響。...

    Swift教程網4412020-12-16
  • SwiftSwift中轉義閉包示例詳解

    Swift中轉義閉包示例詳解

    在Swift 中的閉包類似于結構塊,并可以在任何地方調用,下面這篇文章主要給大家介紹了關于Swift中轉義閉包的相關資料,需要的朋友可以參考下...

    小小小_小朋友11412021-12-26
  • SwiftSwift使用CollectionView實現廣告欄滑動效果

    Swift使用CollectionView實現廣告欄滑動效果

    這篇文章主要為大家詳細介紹了Swift使用CollectionView實現廣告欄滑動效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    Stevin的技術博客12372021-01-13
  • SwiftSwift的74個常用內置函數介紹

    Swift的74個常用內置函數介紹

    這篇文章主要介紹了Swift的74個常用內置函數介紹,這篇文章列舉出了所有的Swift庫函數,內置函數是指無需引入任何模塊即可以直接使用的函數,需要的朋友可...

    Swift教程網5802020-12-19
  • Swiftmac git xcrun error active developer path 錯誤

    mac git xcrun error active developer path 錯誤

    本文主要是講訴了如何解決在mac下使用git;xcode4.6的環境時,出現了錯誤(mac git xcrun error active developer path)的解決辦法,希望對大家有所幫助...

    Swift教程網2232020-12-16
  • SwiftSwift教程之基礎數據類型詳解

    Swift教程之基礎數據類型詳解

    這篇文章主要介紹了Swift教程之基礎數據類型詳解,本文詳細講解了Swift中的基本數據類型和基本語法,例如常量和變量、注釋、分號、整數、數值類型轉換等...

    Swift教程網5162020-12-18
  • SwiftSwift實現多個TableView側滑與切換效果

    Swift實現多個TableView側滑與切換效果

    這篇文章主要為大家詳細介紹了Swift實現多個TableView側滑與切換效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    乞力馬扎羅的雪雪5822021-01-08
主站蜘蛛池模板: 国产成人手机在线好好热 | 国产自产自拍 | 性欧美xxxxx护士另类 | 女同videos双性人 | 亚洲九九爱 | 欧美高清乌克兰精品另类 | 日本在线国产 | 欧美作爱福利免费观看视频 | 亚洲爱视频| 国产自拍啪啪 | 性欧美videofree中文字幕 | 91精品久久一区二区三区 | 嫩草在线观看视频 | 纲手被强喷水羞羞漫画 | 亚洲六月丁香六月婷婷蜜芽 | 波多野结衣在线观看视频 | 星空无限传媒视频在线观看视频 | 国产日韩欧美一区 | 亚洲成人综合在线 | 女人zooxx禽交| 性欧美金发洋妞xxxxbbbb | 午夜精品国产自在现线拍 | 免费在线观看网址大全 | 国产精品视频第一页 | 91香蕉视频网址 | 爱色成人网 | 青青青国产精品国产精品久久久久 | 国产精品自在线拍 | 国产午夜亚洲精品理论片不卡 | 亚洲激情视频在线 | 亚洲成人福利网站 | 99在线资源 | 精品国产品香蕉在线观看75 | 6080欧美一区二区三区四区 | 韩国美女豪爽一级毛片 | 精品国产一区二区在线观看 | 国偷盗摄自产福利一区在线 | 热久久最新视频 | jizzjizz成熟丰满舒服 | 亚洲国产精品一区二区三区久久 | 好涨好大我快受不了了视频网 |