aboutsummaryrefslogtreecommitdiff
path: root/2015/day-05/day-05.rkt
blob: 9714a0f9adcc1a8136babdd59a3d96ad5dc642f3 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
#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)