Skip to content

Commit

Permalink
feat: add swift implementation to lcof problem: No.28 (#2895)
Browse files Browse the repository at this point in the history
  • Loading branch information
klever34 committed May 23, 2024
1 parent cd82966 commit b2923ee
Show file tree
Hide file tree
Showing 2 changed files with 59 additions and 0 deletions.
32 changes: 32 additions & 0 deletions lcof/面试题28. 对称的二叉树/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -308,6 +308,38 @@ public class Solution {
}
```

#### Swift

```swift
/* public class TreeNode {
* var val: Int
* var left: TreeNode?
* var right: TreeNode?
* init(_ val: Int) {
* self.val = val
* self.left = nil
* self.right = nil
* }
* }
*/

class Solution {
func isSymmetric(_ root: TreeNode?) -> Bool {
return dfs(root, root)
}

private func dfs(_ a: TreeNode?, _ b: TreeNode?) -> Bool {
if a == nil && b == nil {
return true
}
if a == nil || b == nil || a!.val != b!.val {
return false
}
return dfs(a!.left, b!.right) && dfs(a!.right, b!.left)
}
}
```

<!-- tabs:end -->

<!-- solution:end -->
Expand Down
27 changes: 27 additions & 0 deletions lcof/面试题28. 对称的二叉树/Solution.swift
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
/* public class TreeNode {
* var val: Int
* var left: TreeNode?
* var right: TreeNode?
* init(_ val: Int) {
* self.val = val
* self.left = nil
* self.right = nil
* }
* }
*/

class Solution {
func isSymmetric(_ root: TreeNode?) -> Bool {
return dfs(root, root)
}

private func dfs(_ a: TreeNode?, _ b: TreeNode?) -> Bool {
if a == nil && b == nil {
return true
}
if a == nil || b == nil || a!.val != b!.val {
return false
}
return dfs(a!.left, b!.right) && dfs(a!.right, b!.left)
}
}

0 comments on commit b2923ee

Please sign in to comment.