aboutsummaryrefslogtreecommitdiff
path: root/racket/aoc2020/day-04/day-04.rkt
diff options
context:
space:
mode:
authorH.J <thechairman@thechairman.info>2024-10-09 11:36:55 -0400
committerH.J <thechairman@thechairman.info>2024-10-09 11:36:55 -0400
commit8777ff071f7bb37631baa7b6717ad29961e50911 (patch)
tree6d59c4ed58e454b960339c3d1151f0a879e8d7cb /racket/aoc2020/day-04/day-04.rkt
parent6156a9ef7be4012063a042aafb4e9b0d7eadde8e (diff)
downloadgleam_aoc-8777ff071f7bb37631baa7b6717ad29961e50911.tar.gz
gleam_aoc-8777ff071f7bb37631baa7b6717ad29961e50911.zip
sorting by language
Diffstat (limited to 'racket/aoc2020/day-04/day-04.rkt')
-rw-r--r--racket/aoc2020/day-04/day-04.rkt64
1 files changed, 64 insertions, 0 deletions
diff --git a/racket/aoc2020/day-04/day-04.rkt b/racket/aoc2020/day-04/day-04.rkt
new file mode 100644
index 0000000..54d50f8
--- /dev/null
+++ b/racket/aoc2020/day-04/day-04.rkt
@@ -0,0 +1,64 @@
+#lang racket
+(require "../../jj-aoc.rkt"
+ threading)
+
+(define passports
+ (~> (open-day 4 2020) (port->string) (string-split "\n\n") (map (λ~> (string-replace "\n" " ")) _)))
+
+;; part 1
+(define required-fields (list "byr:" "iyr:" "eyr:" "hgt:" "hcl:" "ecl:" "pid:"))
+
+(define (valid-passport? p)
+ (andmap (λ (s) (string-contains? p s)) required-fields))
+
+(count valid-passport? passports)
+
+;; part 2
+(define passport-fields
+ (for/list ([p (in-list passports)] #:when (valid-passport? p))
+ (~> p string-split (map (curryr string-split ":") _) flatten (apply hash _))))
+
+(define (between x low high)
+ (and (x . >= . low) (x . <= . high)))
+
+(define (valid-byr? p)
+ (define year (string->number (hash-ref p "byr")))
+ (between year 1920 2002))
+
+(define (valid-iyr? p)
+ (define year (string->number (hash-ref p "iyr")))
+ (between year 2010 2020))
+
+(define (valid-eyr? p)
+ (define year (string->number (hash-ref p "eyr")))
+ (between year 2020 2030))
+
+(define (valid-hgt? p)
+ (define height (hash-ref p "hgt"))
+ (cond
+ [(string-suffix? height "cm")
+ (let ([h (string->number (string-trim height "cm"))]) (between h 150 193))]
+ [(string-suffix? height "in")
+ (let ([h (string->number (string-trim height "in"))]) (between h 59 76))]
+ [else #false]))
+
+(define (valid-hcl? p)
+ (define color (hash-ref p "hcl"))
+ (regexp-match #px"^#[0-9a-f]{6}$" color))
+
+(define (valid-ecl? p)
+ (member (hash-ref p "ecl") (list "amb" "blu" "brn" "gry" "grn" "hzl" "oth")))
+
+(define (valid-pid? p)
+ (regexp-match #px"^\\d{9}$" (hash-ref p "pid")))
+
+(define (valid-stricter-passport? p)
+ (and (valid-byr? p)
+ (valid-iyr? p)
+ (valid-eyr? p)
+ (valid-hgt? p)
+ (valid-hcl? p)
+ (valid-ecl? p)
+ (valid-pid? p)))
+
+(count valid-stricter-passport? passport-fields)