/**
* Beispiel aus
*
* - Algorithmen und Datenstrukturen für Dummies
* - von Andreas Gogol-Döring und Thomas Letschert
* - Verlag Wiley-VCH; Oktober 2019
* - Kapitel 5, Bäume: Immer einer über den anderen
*
* @author A. Gogol-Döring, Th. Letschert
*/
import Foundation
struct AuD_05_02_PreorderTraversal {
enum BinTree : CustomStringConvertible {
case Empty
indirect case Node(value: A,
left: BinTree,
right: BinTree
)
var description : String {
switch self {
case .Empty: return "."
case .Node(let v, let l, let r): return "[\(v), \(l.description), \(r.description) ]"
}
}
}
static func preorder(tree: BinTree) -> [A] {
switch tree {
case .Empty:
return []
case .Node(let v, let l, let r):
return [v] + preorder(tree: l) + preorder(tree: r)
}
}
static func run() {
let tree: BinTree =
.Node(value: 1,
left: .Node(value: 2,
left: .Empty, right: .Empty),
right: .Node(value: 3,
left: .Node(value: 4, left: .Empty, right: .Empty),
right: .Node(value: 5,
left: .Node(value: 6, left: .Empty, right: .Node(value: 7, left: .Empty, right: .Empty)),
right: .Node(value: 8, left: .Empty, right: .Node(value: 9, left: .Empty, right: .Empty)))
)
)
print(preorder(tree: tree))
}
}