27.二叉树的镜像
Last updated
Last updated
func mirrorTree(_ root: TreeNode?) -> TreeNode? {
if root == nil {
return nil
}
let left = root?.left
let right = root?.right
root?.left = mirrorTree(right)
root?.right = mirrorTree(left)
return root
} func mirrorTree2(_ root: TreeNode?) -> TreeNode? {
var stack: [TreeNode?] = [root]
while stack.last != nil {
let node = stack.removeLast()
let right = node?.right
let left = node?.left
if let rn = right {
stack.append(rn)
}
if let ln = left {
stack.append(ln)
}
node?.left = right
node?.right = left
}
return root
}