blob: 3449adcf7e53ff9b9c576f5f7a07da3daa414535 (
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
|
#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)
|