Quellcode durchsuchen

solve leetcode 20

Mistivia vor 1 Jahr
Ursprung
Commit
836d657d12
1 geänderte Dateien mit 33 neuen und 0 gelöschten Zeilen
  1. 33 0
      leetcode/20-valid-parentheses/solution.rkt

+ 33 - 0
leetcode/20-valid-parentheses/solution.rkt

@@ -0,0 +1,33 @@
+#lang racket
+
+;; https://leetcode.com/problems/valid-parentheses/
+
+(define (is-left-paren c)
+    (or (eq? c #\u28)
+        (eq? c #\[)
+        (eq? c #\{)))
+
+(define (right-paren c)
+    (cond ((eq? c #\u28) #\u29)
+          ((eq? c #\[) #\])
+          ((eq? c #\{) #\})))
+
+(define/contract (is-valid s)
+  (-> string? boolean?)
+  (define (loop s stack)
+    (if (= 0 (string-length s))
+        (null? stack)
+        (let ()
+            (define c (string-ref s 0))
+            (define remain (substring s 1))
+            (if (is-left-paren c)
+                (loop remain (cons c stack))
+                (if (null? stack)
+                    #f
+                    (let ()
+                        (define stack-top (car stack))
+                        (if (eq? c (right-paren stack-top))
+                            (loop remain (cdr stack))
+                            #f)))))))
+  (loop s '()))
+