aboutsummaryrefslogtreecommitdiff
path: root/racket/aoc2015/day-05/day-05.rkt
diff options
context:
space:
mode:
Diffstat (limited to 'racket/aoc2015/day-05/day-05.rkt')
-rw-r--r--racket/aoc2015/day-05/day-05.rkt32
1 files changed, 32 insertions, 0 deletions
diff --git a/racket/aoc2015/day-05/day-05.rkt b/racket/aoc2015/day-05/day-05.rkt
new file mode 100644
index 0000000..3449adc
--- /dev/null
+++ b/racket/aoc2015/day-05/day-05.rkt
@@ -0,0 +1,32 @@
+#lang racket
+(require "../../jj-aoc.rkt"
+ threading)
+
+(define strs (port->lines (open-day 5 2015)))
+
+;; part 1
+(define (at-least-three-vowels? str)
+ (~>> str (regexp-replace* #px"[^aeiou]" _ "") string-length (<= 3)))
+
+(define (at-least-one-pair? str)
+ (regexp-match? #px"(.)\\1{1,}" str))
+
+(define (no-forbidden-pairs? str)
+ (~>> (list "ab" "cd" "pq" "xy") (ormap (λ~>> (string-contains? str))) not))
+
+(define (nice? str)
+ (~>> (list at-least-three-vowels? at-least-one-pair? no-forbidden-pairs?) (andmap (λ (f) (f str)))))
+
+(count nice? strs)
+
+;; part 2
+(define (repeating-pair? str)
+ (regexp-match? #px"(..).*\\1" str))
+
+(define (symmetry? str)
+ (regexp-match? #px"(.).\\1" str))
+
+(define (new-nice? str)
+ (~>> (list repeating-pair? symmetry?) (andmap (λ (f) (f str)))))
+
+(count new-nice? strs)