Compare commits
2 commits
37165b60fd
...
9504b4ecab
Author | SHA1 | Date | |
---|---|---|---|
9504b4ecab | |||
136802984d |
20 changed files with 2265 additions and 0 deletions
1
23/.envrc
Normal file
1
23/.envrc
Normal file
|
@ -0,0 +1 @@
|
||||||
|
use flake
|
4
23/elixir/.formatter.exs
Normal file
4
23/elixir/.formatter.exs
Normal file
|
@ -0,0 +1,4 @@
|
||||||
|
# Used by "mix format"
|
||||||
|
[
|
||||||
|
inputs: ["{mix,.formatter}.exs", "{config,lib,test}/**/*.{ex,exs}"]
|
||||||
|
]
|
26
23/elixir/.gitignore
vendored
Normal file
26
23/elixir/.gitignore
vendored
Normal file
|
@ -0,0 +1,26 @@
|
||||||
|
# The directory Mix will write compiled artifacts to.
|
||||||
|
/_build/
|
||||||
|
|
||||||
|
# If you run "mix test --cover", coverage assets end up here.
|
||||||
|
/cover/
|
||||||
|
|
||||||
|
# The directory Mix downloads your dependencies sources to.
|
||||||
|
/deps/
|
||||||
|
|
||||||
|
# Where third-party dependencies like ExDoc output generated docs.
|
||||||
|
/doc/
|
||||||
|
|
||||||
|
# Ignore .fetch files in case you like to edit your project deps locally.
|
||||||
|
/.fetch
|
||||||
|
|
||||||
|
# If the VM crashes, it generates a dump, let's ignore it too.
|
||||||
|
erl_crash.dump
|
||||||
|
|
||||||
|
# Also ignore archive artifacts (built via "mix archive.build").
|
||||||
|
*.ez
|
||||||
|
|
||||||
|
# Ignore package tarball (built via "mix hex.build").
|
||||||
|
aoc-*.tar
|
||||||
|
|
||||||
|
# Temporary files, for example, from tests.
|
||||||
|
/tmp/
|
2
23/elixir/Makefile
Normal file
2
23/elixir/Makefile
Normal file
|
@ -0,0 +1,2 @@
|
||||||
|
day%:
|
||||||
|
mix run -e "AOC.Day$*.solve()"
|
21
23/elixir/README.md
Normal file
21
23/elixir/README.md
Normal file
|
@ -0,0 +1,21 @@
|
||||||
|
# Aoc
|
||||||
|
|
||||||
|
**TODO: Add description**
|
||||||
|
|
||||||
|
## Installation
|
||||||
|
|
||||||
|
If [available in Hex](https://hex.pm/docs/publish), the package can be installed
|
||||||
|
by adding `aoc` to your list of dependencies in `mix.exs`:
|
||||||
|
|
||||||
|
```elixir
|
||||||
|
def deps do
|
||||||
|
[
|
||||||
|
{:aoc, "~> 0.1.0"}
|
||||||
|
]
|
||||||
|
end
|
||||||
|
```
|
||||||
|
|
||||||
|
Documentation can be generated with [ExDoc](https://github.com/elixir-lang/ex_doc)
|
||||||
|
and published on [HexDocs](https://hexdocs.pm). Once published, the docs can
|
||||||
|
be found at <https://hexdocs.pm/aoc>.
|
||||||
|
|
1000
23/elixir/inputs/day7.txt
Normal file
1000
23/elixir/inputs/day7.txt
Normal file
File diff suppressed because it is too large
Load diff
5
23/elixir/inputs/day7_example.txt
Normal file
5
23/elixir/inputs/day7_example.txt
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
32T3K 765
|
||||||
|
T55J5 684
|
||||||
|
KK677 28
|
||||||
|
KTJJT 220
|
||||||
|
QQQJA 483
|
796
23/elixir/inputs/day8.txt
Normal file
796
23/elixir/inputs/day8.txt
Normal file
|
@ -0,0 +1,796 @@
|
||||||
|
LLRLRRLLRLRRLLRLRRLRRRLRLRLRRRLLRLRRRLRLRRRLRLRLLLRRLRLRLLRLRRLRRRLRRRLLRRLRLRRRLRRLRRRLRLLRRLRRRLRRRLRRLRLRRLLLRLRLLRRRLRRLLRLRLRRLLRLRRLLRLRRLRRLLRRRLRLRLRRRLLRRRLRRLRRRLRRRLRLRRRLRRLLLRRRLRLLLRRRLRLLRLLRRRLLRRLRRRLRRRLRLLRLRLRRRLLRRLRRRLRRLRLLRRRLRRLRRRLRRRLRRRLRLRRRLRRRLRLRRRR
|
||||||
|
|
||||||
|
XGS = (FDM, XCS)
|
||||||
|
PJD = (XJN, PCV)
|
||||||
|
FLJ = (VRH, NBF)
|
||||||
|
RXS = (DNN, DHH)
|
||||||
|
DQD = (NTV, CRQ)
|
||||||
|
HGJ = (QJF, JTK)
|
||||||
|
JDL = (QHC, TKN)
|
||||||
|
VMX = (DVX, KDB)
|
||||||
|
SPX = (FMD, MQS)
|
||||||
|
DSQ = (BNF, PDJ)
|
||||||
|
XJQ = (QST, MFT)
|
||||||
|
BGX = (MSH, JQQ)
|
||||||
|
CMT = (FSP, SCN)
|
||||||
|
BVV = (LPL, LPL)
|
||||||
|
MBR = (BHB, RMB)
|
||||||
|
VVP = (QTP, TJC)
|
||||||
|
BFC = (SMR, SMR)
|
||||||
|
DTN = (CMN, NVG)
|
||||||
|
BVN = (BKM, KPN)
|
||||||
|
BCR = (MHM, MPT)
|
||||||
|
NDK = (NHG, RVN)
|
||||||
|
FRR = (NKL, KKN)
|
||||||
|
XDP = (GBQ, VGF)
|
||||||
|
KCS = (CXN, GGR)
|
||||||
|
HLG = (FMQ, NXV)
|
||||||
|
MTP = (KFV, QCH)
|
||||||
|
VFH = (GPQ, RFK)
|
||||||
|
HSG = (JKV, KNK)
|
||||||
|
THL = (CPG, BBF)
|
||||||
|
FJP = (CVM, BVF)
|
||||||
|
TGR = (LNL, JGD)
|
||||||
|
JJD = (QLT, QMC)
|
||||||
|
DQK = (NDK, NFS)
|
||||||
|
KFN = (PJK, XSJ)
|
||||||
|
QLN = (NKV, MGT)
|
||||||
|
GJR = (HBJ, HLG)
|
||||||
|
JXD = (NFK, KMD)
|
||||||
|
CGM = (QHF, PJR)
|
||||||
|
FPM = (DHB, VBS)
|
||||||
|
NMK = (MVX, MFM)
|
||||||
|
SJQ = (VBD, GKP)
|
||||||
|
XVX = (KCS, TNV)
|
||||||
|
FNC = (BCR, LQB)
|
||||||
|
KLA = (XKM, DNG)
|
||||||
|
CHD = (TPM, BHH)
|
||||||
|
RMV = (PBC, QPM)
|
||||||
|
BXH = (QDC, LKX)
|
||||||
|
VQK = (HRJ, LBX)
|
||||||
|
VNR = (SDB, JQL)
|
||||||
|
TQS = (JPX, NLL)
|
||||||
|
RPK = (KTX, XKP)
|
||||||
|
AAA = (XMG, HJX)
|
||||||
|
NQS = (TGB, RDK)
|
||||||
|
JKK = (SFX, VDH)
|
||||||
|
DKM = (RXJ, DXF)
|
||||||
|
VGF = (MXT, LKT)
|
||||||
|
KQN = (KTG, NCT)
|
||||||
|
MXV = (HFT, QJM)
|
||||||
|
CKP = (FMC, JPT)
|
||||||
|
HGP = (JMV, DXV)
|
||||||
|
VRC = (NVR, NHK)
|
||||||
|
DPR = (VBV, FLJ)
|
||||||
|
VBL = (PXB, BVN)
|
||||||
|
GSG = (KSL, VSX)
|
||||||
|
FNK = (VPD, NKN)
|
||||||
|
LVB = (SQB, SQB)
|
||||||
|
PRF = (HNP, TDG)
|
||||||
|
TGV = (NVR, NHK)
|
||||||
|
DXV = (QNK, PKL)
|
||||||
|
KMP = (KVB, VMR)
|
||||||
|
BTR = (LKF, PJD)
|
||||||
|
QHC = (DFT, DTJ)
|
||||||
|
RXM = (LRG, NPH)
|
||||||
|
KTX = (RFR, QRT)
|
||||||
|
JHR = (BRV, QRB)
|
||||||
|
JDH = (BFX, DTN)
|
||||||
|
JLQ = (TTV, GKH)
|
||||||
|
CMQ = (HQL, PJP)
|
||||||
|
DJF = (JTK, QJF)
|
||||||
|
KVB = (MXL, PTK)
|
||||||
|
DMD = (HXP, ZZZ)
|
||||||
|
XJV = (CRV, JLM)
|
||||||
|
JXR = (JMQ, LQM)
|
||||||
|
DFT = (DRN, JQM)
|
||||||
|
JSC = (XFX, XFX)
|
||||||
|
CKB = (VVK, XBK)
|
||||||
|
RFJ = (CKP, QMH)
|
||||||
|
HRP = (LQT, CJV)
|
||||||
|
HXJ = (CKB, FCT)
|
||||||
|
DMX = (CRV, JLM)
|
||||||
|
XBK = (LVB, FXN)
|
||||||
|
JVP = (SKF, LCK)
|
||||||
|
JLV = (VPT, DMK)
|
||||||
|
SXK = (TNR, MTF)
|
||||||
|
DTJ = (JQM, DRN)
|
||||||
|
KLN = (FDX, NPN)
|
||||||
|
SKG = (BTR, HXG)
|
||||||
|
RFR = (XCT, FHN)
|
||||||
|
FKB = (JJL, CGM)
|
||||||
|
HNP = (DKR, JLQ)
|
||||||
|
HKC = (FDM, XCS)
|
||||||
|
QQN = (MTP, DCG)
|
||||||
|
QRX = (RPJ, PQM)
|
||||||
|
SMD = (BBD, DSQ)
|
||||||
|
SFJ = (JMR, JMR)
|
||||||
|
CJZ = (QMH, CKP)
|
||||||
|
PGB = (SDJ, LQF)
|
||||||
|
CMS = (XSG, TFG)
|
||||||
|
JMV = (PKL, QNK)
|
||||||
|
GHH = (RHT, RXS)
|
||||||
|
NLN = (XJX, MVC)
|
||||||
|
RCG = (DCG, MTP)
|
||||||
|
XHF = (SSF, CBS)
|
||||||
|
PNC = (GPB, MJJ)
|
||||||
|
RXC = (XHF, LDN)
|
||||||
|
XVM = (NKR, KQG)
|
||||||
|
MTF = (FKN, FKV)
|
||||||
|
FGM = (JPJ, DFG)
|
||||||
|
MTG = (RRX, FFL)
|
||||||
|
HCC = (RFS, PBH)
|
||||||
|
TJL = (RPJ, PQM)
|
||||||
|
RDK = (RLT, MMJ)
|
||||||
|
CSD = (MDQ, HSG)
|
||||||
|
KVP = (VRC, TGV)
|
||||||
|
QJM = (LSF, DQK)
|
||||||
|
TTV = (RCC, LXJ)
|
||||||
|
TJC = (RDG, LFV)
|
||||||
|
BFS = (FFL, RRX)
|
||||||
|
BRV = (NRJ, HCN)
|
||||||
|
HXP = (XMG, HJX)
|
||||||
|
NJK = (MJT, GBX)
|
||||||
|
DGV = (NDH, DPB)
|
||||||
|
RGD = (KBH, XDP)
|
||||||
|
CRV = (QBD, QLJ)
|
||||||
|
RPS = (LPH, PRR)
|
||||||
|
PLF = (BHH, TPM)
|
||||||
|
SJF = (LFB, NMD)
|
||||||
|
HLQ = (XJX, MVC)
|
||||||
|
SJR = (XKM, DNG)
|
||||||
|
TQP = (BTG, QJG)
|
||||||
|
MTJ = (JPJ, DFG)
|
||||||
|
SQB = (RFJ, RFJ)
|
||||||
|
KPN = (VTC, LDH)
|
||||||
|
BDZ = (CQP, HRP)
|
||||||
|
QFC = (XJQ, PMR)
|
||||||
|
XMV = (HTS, RXT)
|
||||||
|
MQS = (FXV, VCL)
|
||||||
|
TLQ = (XMV, TSC)
|
||||||
|
TCQ = (CXH, RCV)
|
||||||
|
KNK = (CBD, VQK)
|
||||||
|
GHD = (DBJ, VPK)
|
||||||
|
TKP = (TXK, MPJ)
|
||||||
|
CCC = (NKL, KKN)
|
||||||
|
QFN = (TJD, JDJ)
|
||||||
|
DVJ = (GQM, QKJ)
|
||||||
|
TNC = (PVV, PMJ)
|
||||||
|
HJX = (DQD, JDR)
|
||||||
|
NFF = (JMR, GTZ)
|
||||||
|
JSB = (SLS, HSC)
|
||||||
|
NVR = (CTV, PNS)
|
||||||
|
FNV = (XLK, FNC)
|
||||||
|
JVR = (TGB, RDK)
|
||||||
|
TXM = (SNN, DMZ)
|
||||||
|
CNF = (KLN, BDB)
|
||||||
|
QRG = (PDS, MHP)
|
||||||
|
QVV = (JJD, RLL)
|
||||||
|
XML = (VMR, KVB)
|
||||||
|
TLB = (NTD, VKD)
|
||||||
|
SDJ = (CNQ, FNV)
|
||||||
|
TKN = (DTJ, DFT)
|
||||||
|
HFK = (LPF, XPH)
|
||||||
|
LJP = (SFJ, SFJ)
|
||||||
|
SMX = (RQV, DDH)
|
||||||
|
JBL = (XML, KMP)
|
||||||
|
NDA = (PBF, FHP)
|
||||||
|
LRP = (XKP, KTX)
|
||||||
|
JCK = (BGC, CNF)
|
||||||
|
XCF = (SPJ, CVR)
|
||||||
|
VNV = (CMQ, JPQ)
|
||||||
|
BPJ = (XVP, DXQ)
|
||||||
|
MVC = (QFC, DLV)
|
||||||
|
QRK = (SDJ, LQF)
|
||||||
|
BFX = (CMN, NVG)
|
||||||
|
JMQ = (MFC, RXD)
|
||||||
|
JPQ = (PJP, HQL)
|
||||||
|
FCN = (NPH, LRG)
|
||||||
|
RXQ = (FMG, GJF)
|
||||||
|
DVX = (GSS, CFM)
|
||||||
|
CSH = (VQF, PTV)
|
||||||
|
STM = (CFH, BMQ)
|
||||||
|
NVF = (CSH, VHC)
|
||||||
|
CKG = (VSX, KSL)
|
||||||
|
BLG = (QHJ, DLB)
|
||||||
|
RCB = (VVX, XCF)
|
||||||
|
MGX = (HGT, HGP)
|
||||||
|
NVG = (KMC, VSM)
|
||||||
|
JLM = (QBD, QLJ)
|
||||||
|
NKR = (HCD, RQC)
|
||||||
|
QKJ = (VXK, TRR)
|
||||||
|
XSJ = (TCQ, PCL)
|
||||||
|
HQP = (HSJ, DGV)
|
||||||
|
NPQ = (RBR, FNB)
|
||||||
|
DDH = (PTQ, KQN)
|
||||||
|
KTG = (DHL, KSX)
|
||||||
|
MHP = (FCX, VCB)
|
||||||
|
LBA = (CKP, QMH)
|
||||||
|
GBX = (DLC, JRX)
|
||||||
|
TKX = (RNJ, PPC)
|
||||||
|
FHK = (KCV, NBK)
|
||||||
|
CJV = (RCG, QQN)
|
||||||
|
PPC = (JDH, SBM)
|
||||||
|
KKN = (KVP, HBC)
|
||||||
|
HBT = (XDM, PGN)
|
||||||
|
CNC = (FVV, TCX)
|
||||||
|
MXL = (BMP, BPJ)
|
||||||
|
XVP = (TRL, HVN)
|
||||||
|
XLX = (JSK, KNX)
|
||||||
|
FCT = (VVK, XBK)
|
||||||
|
CFH = (VRX, XMK)
|
||||||
|
TNV = (CXN, GGR)
|
||||||
|
JHK = (VQR, LDL)
|
||||||
|
JPJ = (JBL, NBC)
|
||||||
|
TNR = (FKV, FKN)
|
||||||
|
RXJ = (SKG, BFK)
|
||||||
|
QDV = (RHT, RXS)
|
||||||
|
QQQ = (XHH, JVP)
|
||||||
|
HGS = (MFV, DKC)
|
||||||
|
NBK = (LNV, QLN)
|
||||||
|
LDL = (CRJ, PRF)
|
||||||
|
JRL = (KJS, PVK)
|
||||||
|
FXR = (HCS, CMT)
|
||||||
|
NVX = (GJR, GTQ)
|
||||||
|
CFM = (SMT, SXK)
|
||||||
|
TFG = (SPN, TLF)
|
||||||
|
PPF = (KJN, NXJ)
|
||||||
|
VPV = (HQP, KRB)
|
||||||
|
MGT = (TJL, QRX)
|
||||||
|
LGB = (KBH, XDP)
|
||||||
|
BNS = (CTP, CBL)
|
||||||
|
KSX = (BFS, MTG)
|
||||||
|
GDD = (NBP, STP)
|
||||||
|
CJQ = (VHM, JNQ)
|
||||||
|
GQC = (NTD, VKD)
|
||||||
|
FMC = (SKX, LRF)
|
||||||
|
PTQ = (KTG, NCT)
|
||||||
|
KNG = (BRV, QRB)
|
||||||
|
KQG = (RQC, HCD)
|
||||||
|
NSG = (HXJ, LBP)
|
||||||
|
QPM = (KPK, XVX)
|
||||||
|
CXH = (LGS, LQR)
|
||||||
|
LCF = (GBS, MHB)
|
||||||
|
VBD = (MBR, NBJ)
|
||||||
|
SDB = (SVM, JJM)
|
||||||
|
DCR = (FVK, KGG)
|
||||||
|
BDJ = (XRG, CQL)
|
||||||
|
JMR = (VRM, NFN)
|
||||||
|
XFR = (LQM, JMQ)
|
||||||
|
MBP = (CBL, CTP)
|
||||||
|
GVD = (CLB, FMF)
|
||||||
|
MFH = (PPC, RNJ)
|
||||||
|
PTK = (BMP, BPJ)
|
||||||
|
LGJ = (PXP, HJK)
|
||||||
|
GKP = (MBR, NBJ)
|
||||||
|
HXG = (LKF, PJD)
|
||||||
|
NBC = (XML, KMP)
|
||||||
|
SJG = (LPF, XPH)
|
||||||
|
BKM = (VTC, LDH)
|
||||||
|
DKC = (NQS, JVR)
|
||||||
|
JSJ = (TQP, RLR)
|
||||||
|
PMR = (QST, MFT)
|
||||||
|
BRM = (PRR, LPH)
|
||||||
|
KRL = (BGX, XNX)
|
||||||
|
TCX = (GQC, TLB)
|
||||||
|
QLJ = (FPS, JFN)
|
||||||
|
HCD = (FXR, PJJ)
|
||||||
|
TBN = (DSJ, VPV)
|
||||||
|
FFL = (NBB, FKB)
|
||||||
|
GRN = (HCC, NJF)
|
||||||
|
LQB = (MHM, MPT)
|
||||||
|
SFX = (LGB, RGD)
|
||||||
|
HJB = (VNR, KFT)
|
||||||
|
HRJ = (GLC, CHR)
|
||||||
|
MJT = (DLC, JRX)
|
||||||
|
FHN = (HHG, RMV)
|
||||||
|
VTJ = (BFC, JTL)
|
||||||
|
CQP = (CJV, LQT)
|
||||||
|
VCB = (NGR, JRL)
|
||||||
|
VNN = (JKK, SCK)
|
||||||
|
XNT = (RXQ, LJS)
|
||||||
|
SCN = (TNC, LGP)
|
||||||
|
FMF = (TKP, NNT)
|
||||||
|
VSM = (HNF, RLF)
|
||||||
|
CNQ = (FNC, XLK)
|
||||||
|
MPT = (TLQ, SBG)
|
||||||
|
DSJ = (KRB, HQP)
|
||||||
|
CXV = (QRK, PGB)
|
||||||
|
LBX = (GLC, CHR)
|
||||||
|
VBV = (NBF, VRH)
|
||||||
|
TJQ = (LCH, HTJ)
|
||||||
|
CPG = (QVC, CJQ)
|
||||||
|
KJN = (PLB, DGH)
|
||||||
|
NCM = (VTJ, SXJ)
|
||||||
|
FXV = (NCM, SDH)
|
||||||
|
XRG = (DPR, MXD)
|
||||||
|
LCM = (PMN, VCS)
|
||||||
|
SHN = (SMK, PHG)
|
||||||
|
MXD = (FLJ, VBV)
|
||||||
|
FDJ = (LKV, BKX)
|
||||||
|
JDR = (NTV, CRQ)
|
||||||
|
XDR = (LPV, XTH)
|
||||||
|
RNJ = (JDH, SBM)
|
||||||
|
FHP = (MGQ, HJB)
|
||||||
|
PVH = (GPQ, GPQ)
|
||||||
|
MGM = (RBS, HPR)
|
||||||
|
VFQ = (RBR, FNB)
|
||||||
|
XRV = (LCH, HTJ)
|
||||||
|
DGP = (FDJ, GTJ)
|
||||||
|
HJV = (DHB, VBS)
|
||||||
|
KPK = (TNV, KCS)
|
||||||
|
CMX = (DBJ, VPK)
|
||||||
|
BHH = (VRN, SMX)
|
||||||
|
PJL = (NLS, SCL)
|
||||||
|
SPJ = (RXM, FCN)
|
||||||
|
NTV = (TSJ, BSR)
|
||||||
|
FXN = (SQB, GLR)
|
||||||
|
DTK = (VVP, TCD)
|
||||||
|
DBJ = (MFH, TKX)
|
||||||
|
DCJ = (BTP, GVD)
|
||||||
|
NMD = (DJB, MGC)
|
||||||
|
PBC = (XVX, KPK)
|
||||||
|
FRS = (KMD, NFK)
|
||||||
|
LNL = (SQC, DTK)
|
||||||
|
NGH = (XKL, HPT)
|
||||||
|
RFS = (CHD, PLF)
|
||||||
|
DMK = (JJT, FHK)
|
||||||
|
SNS = (SHN, BMD)
|
||||||
|
RLR = (BTG, QJG)
|
||||||
|
FDM = (GRN, CBK)
|
||||||
|
PLB = (CCT, JTT)
|
||||||
|
VTC = (CMS, XSC)
|
||||||
|
XKM = (QGF, TBN)
|
||||||
|
MVJ = (SLB, TXM)
|
||||||
|
PKL = (CSQ, SJQ)
|
||||||
|
SLB = (SNN, SNN)
|
||||||
|
JKV = (VQK, CBD)
|
||||||
|
BBD = (BNF, PDJ)
|
||||||
|
GSS = (SXK, SMT)
|
||||||
|
LRG = (SPB, TGR)
|
||||||
|
FDN = (JXD, FRS)
|
||||||
|
XKX = (HXC, PGT)
|
||||||
|
PDJ = (FRR, CCC)
|
||||||
|
HXM = (VNN, VJG)
|
||||||
|
QMC = (CXV, TLH)
|
||||||
|
GLG = (GGV, VBL)
|
||||||
|
RXT = (LCF, GBT)
|
||||||
|
TGL = (NXJ, KJN)
|
||||||
|
JPT = (SKX, LRF)
|
||||||
|
NLL = (SPX, DDQ)
|
||||||
|
BHB = (RGP, FQL)
|
||||||
|
XKN = (HBT, XXG)
|
||||||
|
RLT = (JLB, BDJ)
|
||||||
|
SHF = (HGP, HGT)
|
||||||
|
HKV = (DLB, QHJ)
|
||||||
|
SVM = (XDR, BLN)
|
||||||
|
PMN = (QTL, QRG)
|
||||||
|
CXN = (JLV, FMT)
|
||||||
|
GQV = (PJK, XSJ)
|
||||||
|
HMM = (MGX, SHF)
|
||||||
|
VSC = (PDH, XVM)
|
||||||
|
LCK = (NSG, JPR)
|
||||||
|
JQL = (JJM, SVM)
|
||||||
|
FRQ = (SVG, DCR)
|
||||||
|
TDG = (JLQ, DKR)
|
||||||
|
SMT = (TNR, MTF)
|
||||||
|
GBT = (GBS, MHB)
|
||||||
|
QMH = (JPT, FMC)
|
||||||
|
DXJ = (CMQ, JPQ)
|
||||||
|
JJM = (XDR, BLN)
|
||||||
|
DDQ = (FMD, MQS)
|
||||||
|
NDH = (VVQ, DCM)
|
||||||
|
LSF = (NFS, NDK)
|
||||||
|
VGM = (STS, XNT)
|
||||||
|
PJR = (GXF, JDL)
|
||||||
|
XFC = (XVM, PDH)
|
||||||
|
LBP = (CKB, FCT)
|
||||||
|
KFT = (SDB, JQL)
|
||||||
|
TTT = (QLS, GCV)
|
||||||
|
LPH = (SJF, BPT)
|
||||||
|
JGS = (XKL, HPT)
|
||||||
|
VDH = (LGB, RGD)
|
||||||
|
VHC = (VQF, PTV)
|
||||||
|
NKN = (GDD, XDC)
|
||||||
|
RND = (VGM, PSD)
|
||||||
|
QVC = (VHM, JNQ)
|
||||||
|
JJL = (QHF, PJR)
|
||||||
|
QRB = (NRJ, HCN)
|
||||||
|
MJJ = (FQT, RXC)
|
||||||
|
NNA = (HRP, CQP)
|
||||||
|
PBF = (MGQ, HJB)
|
||||||
|
VRT = (DSS, FDN)
|
||||||
|
DCM = (CLV, JCK)
|
||||||
|
QLS = (SJR, SJR)
|
||||||
|
RMT = (XHH, JVP)
|
||||||
|
DMR = (MLF, MVJ)
|
||||||
|
QJG = (NLN, HLQ)
|
||||||
|
DLV = (XJQ, PMR)
|
||||||
|
LKF = (XJN, PCV)
|
||||||
|
VQR = (PRF, CRJ)
|
||||||
|
SXJ = (BFC, JTL)
|
||||||
|
MDQ = (KNK, JKV)
|
||||||
|
QVD = (BVF, CVM)
|
||||||
|
TGG = (LPL, BDZ)
|
||||||
|
HDJ = (HGB, HSH)
|
||||||
|
HTT = (LHQ, HGS)
|
||||||
|
SKX = (HXM, JMF)
|
||||||
|
FCX = (NGR, JRL)
|
||||||
|
HSJ = (NDH, DPB)
|
||||||
|
BFK = (HXG, BTR)
|
||||||
|
XSG = (SPN, TLF)
|
||||||
|
NCD = (MFM, MVX)
|
||||||
|
PHG = (BKS, SMD)
|
||||||
|
XMK = (QVD, FJP)
|
||||||
|
FXL = (PGT, HXC)
|
||||||
|
KBH = (VGF, GBQ)
|
||||||
|
CBG = (QDC, LKX)
|
||||||
|
LDN = (SSF, CBS)
|
||||||
|
SVG = (FVK, KGG)
|
||||||
|
BVF = (GHH, QDV)
|
||||||
|
SPB = (LNL, JGD)
|
||||||
|
LQR = (QXX, LCM)
|
||||||
|
KHV = (JSK, KNX)
|
||||||
|
LFV = (XFJ, XKN)
|
||||||
|
QHG = (JJD, RLL)
|
||||||
|
HGB = (LRP, RPK)
|
||||||
|
NRJ = (DXJ, VNV)
|
||||||
|
LKT = (PNC, LJX)
|
||||||
|
MSH = (CDN, DMS)
|
||||||
|
MLF = (SLB, SLB)
|
||||||
|
MMJ = (JLB, BDJ)
|
||||||
|
VRM = (HSR, HTT)
|
||||||
|
MHM = (TLQ, SBG)
|
||||||
|
LRF = (HXM, JMF)
|
||||||
|
VHM = (PVH, VFH)
|
||||||
|
FQL = (XRV, TJQ)
|
||||||
|
MPJ = (LFS, CFJ)
|
||||||
|
LMF = (CNC, KCC)
|
||||||
|
JTK = (XJR, DGP)
|
||||||
|
HFT = (DQK, LSF)
|
||||||
|
RQV = (PTQ, KQN)
|
||||||
|
LDT = (BMQ, CFH)
|
||||||
|
RGP = (TJQ, XRV)
|
||||||
|
SDH = (VTJ, SXJ)
|
||||||
|
LKV = (JVB, TFD)
|
||||||
|
KDD = (XFX, XGV)
|
||||||
|
CVM = (GHH, QDV)
|
||||||
|
PLS = (DVX, KDB)
|
||||||
|
VCL = (NCM, SDH)
|
||||||
|
SCK = (SFX, VDH)
|
||||||
|
LJX = (MJJ, GPB)
|
||||||
|
JTT = (LMF, SVS)
|
||||||
|
PHV = (KRL, SVD)
|
||||||
|
PDS = (VCB, FCX)
|
||||||
|
VPD = (XDC, GDD)
|
||||||
|
VRJ = (HXP, HXP)
|
||||||
|
LPV = (HKC, XGS)
|
||||||
|
BDB = (FDX, NPN)
|
||||||
|
DXF = (BFK, SKG)
|
||||||
|
FMG = (JGS, NGH)
|
||||||
|
NXV = (LJP, SBT)
|
||||||
|
PQM = (QVV, QHG)
|
||||||
|
SNN = (PBF, FHP)
|
||||||
|
LGP = (PMJ, PVV)
|
||||||
|
FKV = (CBG, BXH)
|
||||||
|
VJG = (JKK, SCK)
|
||||||
|
JPR = (HXJ, LBP)
|
||||||
|
TPM = (SMX, VRN)
|
||||||
|
KXT = (VQR, LDL)
|
||||||
|
NPN = (FRQ, SRD)
|
||||||
|
TRL = (DCJ, BLS)
|
||||||
|
CBK = (NJF, HCC)
|
||||||
|
KMD = (GQV, KFN)
|
||||||
|
GQM = (TRR, VXK)
|
||||||
|
QST = (RMT, QQQ)
|
||||||
|
XDM = (KXT, JHK)
|
||||||
|
TLH = (QRK, PGB)
|
||||||
|
VRH = (BNS, MBP)
|
||||||
|
VVK = (LVB, LVB)
|
||||||
|
HVN = (BLS, DCJ)
|
||||||
|
TLJ = (HSG, MDQ)
|
||||||
|
QLQ = (STM, LDT)
|
||||||
|
LKX = (DBT, XTS)
|
||||||
|
VXK = (DKM, KKV)
|
||||||
|
XKL = (NPQ, VFQ)
|
||||||
|
LDP = (BPH, RCB)
|
||||||
|
VRN = (RQV, DDH)
|
||||||
|
LJS = (FMG, GJF)
|
||||||
|
FMT = (DMK, VPT)
|
||||||
|
BPT = (LFB, NMD)
|
||||||
|
RLL = (QMC, QLT)
|
||||||
|
JNQ = (PVH, VFH)
|
||||||
|
HJK = (JSC, KDD)
|
||||||
|
QHF = (JDL, GXF)
|
||||||
|
DGH = (JTT, CCT)
|
||||||
|
PVV = (RND, XCQ)
|
||||||
|
XFX = (VRJ, VRJ)
|
||||||
|
NRN = (GQM, QKJ)
|
||||||
|
VPK = (TKX, MFH)
|
||||||
|
GLC = (PPF, TGL)
|
||||||
|
JJT = (KCV, NBK)
|
||||||
|
FVK = (XQS, PJL)
|
||||||
|
VRD = (RCB, BPH)
|
||||||
|
GPQ = (BVV, BVV)
|
||||||
|
XCT = (HHG, RMV)
|
||||||
|
VMR = (PTK, MXL)
|
||||||
|
NTD = (XJV, DMX)
|
||||||
|
CBS = (GHD, CMX)
|
||||||
|
SNZ = (DNG, XKM)
|
||||||
|
QTP = (LFV, RDG)
|
||||||
|
DMZ = (FHP, PBF)
|
||||||
|
LQT = (RCG, QQN)
|
||||||
|
FPS = (RBX, DMR)
|
||||||
|
LGS = (LCM, QXX)
|
||||||
|
ZZZ = (HJX, XMG)
|
||||||
|
RCV = (LQR, LGS)
|
||||||
|
PBH = (CHD, PLF)
|
||||||
|
JPX = (DDQ, SPX)
|
||||||
|
DNN = (MXV, DVB)
|
||||||
|
QRT = (XCT, FHN)
|
||||||
|
HHG = (PBC, QPM)
|
||||||
|
SBM = (BFX, DTN)
|
||||||
|
JVB = (VSC, XFC)
|
||||||
|
QNK = (CSQ, SJQ)
|
||||||
|
BPM = (KNG, JHR)
|
||||||
|
HBC = (TGV, VRC)
|
||||||
|
MGQ = (VNR, KFT)
|
||||||
|
BTP = (CLB, FMF)
|
||||||
|
SVD = (BGX, XNX)
|
||||||
|
RHT = (DHH, DNN)
|
||||||
|
KJS = (FRN, JSB)
|
||||||
|
BLS = (GVD, BTP)
|
||||||
|
TJD = (JXR, XFR)
|
||||||
|
RMS = (HJV, FPM)
|
||||||
|
MFV = (JVR, NQS)
|
||||||
|
DXQ = (HVN, TRL)
|
||||||
|
HSC = (BRM, RPS)
|
||||||
|
CCP = (GGV, VBL)
|
||||||
|
GTB = (QKQ, PHV)
|
||||||
|
RBX = (MLF, MLF)
|
||||||
|
MDN = (GBX, MJT)
|
||||||
|
HXC = (KPF, DJL)
|
||||||
|
HSR = (HGS, LHQ)
|
||||||
|
BMD = (PHG, SMK)
|
||||||
|
GTZ = (NFN, VRM)
|
||||||
|
LDH = (CMS, XSC)
|
||||||
|
NXJ = (PLB, DGH)
|
||||||
|
FGR = (GJR, GTQ)
|
||||||
|
KKV = (RXJ, DXF)
|
||||||
|
XCQ = (PSD, VGM)
|
||||||
|
JQQ = (DMS, CDN)
|
||||||
|
XCS = (GRN, CBK)
|
||||||
|
JQM = (FNK, DKQ)
|
||||||
|
DNG = (QGF, TBN)
|
||||||
|
GBQ = (MXT, LKT)
|
||||||
|
QLT = (TLH, CXV)
|
||||||
|
HTL = (NLL, JPX)
|
||||||
|
DLB = (VRF, THL)
|
||||||
|
GTQ = (HBJ, HLG)
|
||||||
|
NBB = (CGM, JJL)
|
||||||
|
GPB = (FQT, RXC)
|
||||||
|
QBD = (FPS, JFN)
|
||||||
|
NHG = (NRN, DVJ)
|
||||||
|
TRR = (KKV, DKM)
|
||||||
|
DJB = (XKX, FXL)
|
||||||
|
CBD = (HRJ, LBX)
|
||||||
|
CFJ = (BPM, RPN)
|
||||||
|
TXK = (CFJ, LFS)
|
||||||
|
TCD = (QTP, TJC)
|
||||||
|
XTS = (GLG, CCP)
|
||||||
|
PGN = (KXT, JHK)
|
||||||
|
BMP = (XVP, DXQ)
|
||||||
|
CQL = (MXD, DPR)
|
||||||
|
HGT = (DXV, JMV)
|
||||||
|
JDJ = (XFR, JXR)
|
||||||
|
KRB = (HSJ, DGV)
|
||||||
|
BSR = (VRT, GTK)
|
||||||
|
RMB = (RGP, FQL)
|
||||||
|
BKS = (BBD, DSQ)
|
||||||
|
LQM = (RXD, MFC)
|
||||||
|
RQC = (FXR, PJJ)
|
||||||
|
TSC = (RXT, HTS)
|
||||||
|
XPH = (HGJ, DJF)
|
||||||
|
NPH = (TGR, SPB)
|
||||||
|
SCL = (HDJ, PQL)
|
||||||
|
XHH = (LCK, SKF)
|
||||||
|
CBL = (MTJ, FGM)
|
||||||
|
VQF = (QLQ, XLH)
|
||||||
|
LPL = (HRP, CQP)
|
||||||
|
VKD = (DMX, XJV)
|
||||||
|
XJX = (DLV, QFC)
|
||||||
|
KCC = (TCX, FVV)
|
||||||
|
GJK = (RMS, RFL)
|
||||||
|
JTL = (SMR, TTT)
|
||||||
|
XMG = (JDR, DQD)
|
||||||
|
PQL = (HSH, HGB)
|
||||||
|
LCH = (GJK, DMM)
|
||||||
|
PMJ = (RND, XCQ)
|
||||||
|
FRN = (SLS, HSC)
|
||||||
|
CHR = (PPF, TGL)
|
||||||
|
DFG = (NBC, JBL)
|
||||||
|
PJJ = (HCS, CMT)
|
||||||
|
CRJ = (HNP, TDG)
|
||||||
|
RLF = (JSJ, GMJ)
|
||||||
|
GKH = (LXJ, RCC)
|
||||||
|
RNT = (TJD, JDJ)
|
||||||
|
CLV = (CNF, BGC)
|
||||||
|
DRN = (FNK, DKQ)
|
||||||
|
RDG = (XKN, XFJ)
|
||||||
|
BNF = (CCC, FRR)
|
||||||
|
HQH = (HPR, RBS)
|
||||||
|
QJF = (DGP, XJR)
|
||||||
|
NJF = (PBH, RFS)
|
||||||
|
FKN = (CBG, BXH)
|
||||||
|
FSP = (LGP, TNC)
|
||||||
|
RXD = (SJG, HFK)
|
||||||
|
PCL = (RCV, CXH)
|
||||||
|
CLB = (NNT, TKP)
|
||||||
|
XNX = (JQQ, MSH)
|
||||||
|
VVQ = (JCK, CLV)
|
||||||
|
DHH = (DVB, MXV)
|
||||||
|
MXT = (LJX, PNC)
|
||||||
|
MFC = (SJG, HFK)
|
||||||
|
QKQ = (SVD, KRL)
|
||||||
|
CVR = (FCN, RXM)
|
||||||
|
RFK = (BVV, TGG)
|
||||||
|
NBP = (HQH, MGM)
|
||||||
|
QXX = (VCS, PMN)
|
||||||
|
PVK = (FRN, JSB)
|
||||||
|
HCN = (DXJ, VNV)
|
||||||
|
XLK = (LQB, BCR)
|
||||||
|
HPR = (HMM, CNT)
|
||||||
|
VDF = (PHV, QKQ)
|
||||||
|
KNX = (LGJ, CMC)
|
||||||
|
PXB = (KPN, BKM)
|
||||||
|
HNF = (GMJ, JSJ)
|
||||||
|
DKR = (GKH, TTV)
|
||||||
|
NGR = (KJS, PVK)
|
||||||
|
QDC = (XTS, DBT)
|
||||||
|
LPF = (DJF, HGJ)
|
||||||
|
LXJ = (FGR, NVX)
|
||||||
|
NBJ = (RMB, BHB)
|
||||||
|
QGF = (DSJ, VPV)
|
||||||
|
KSL = (QFN, RNT)
|
||||||
|
DHL = (BFS, MTG)
|
||||||
|
STP = (MGM, HQH)
|
||||||
|
FMQ = (LJP, LJP)
|
||||||
|
TGB = (RLT, MMJ)
|
||||||
|
TLF = (NCD, NMK)
|
||||||
|
NLS = (PQL, HDJ)
|
||||||
|
HRG = (SHN, BMD)
|
||||||
|
DMM = (RMS, RFL)
|
||||||
|
VPT = (JJT, FHK)
|
||||||
|
SKF = (JPR, NSG)
|
||||||
|
NFN = (HTT, HSR)
|
||||||
|
KGG = (PJL, XQS)
|
||||||
|
DHB = (CSD, TLJ)
|
||||||
|
QVA = (VRM, NFN)
|
||||||
|
SSF = (GHD, CMX)
|
||||||
|
LFB = (DJB, MGC)
|
||||||
|
GMJ = (TQP, RLR)
|
||||||
|
HTS = (GBT, LCF)
|
||||||
|
FQT = (LDN, XHF)
|
||||||
|
TFD = (VSC, XFC)
|
||||||
|
CMC = (PXP, HJK)
|
||||||
|
VBS = (CSD, TLJ)
|
||||||
|
DLC = (KHV, XLX)
|
||||||
|
NKV = (TJL, QRX)
|
||||||
|
KFV = (GSG, CKG)
|
||||||
|
GGV = (BVN, PXB)
|
||||||
|
DKQ = (NKN, VPD)
|
||||||
|
SLS = (RPS, BRM)
|
||||||
|
PJP = (VDF, GTB)
|
||||||
|
BTG = (NLN, HLQ)
|
||||||
|
VCS = (QTL, QRG)
|
||||||
|
CSQ = (GKP, VBD)
|
||||||
|
CCT = (LMF, SVS)
|
||||||
|
NNT = (TXK, MPJ)
|
||||||
|
XTH = (XGS, HKC)
|
||||||
|
SMK = (BKS, SMD)
|
||||||
|
HCS = (SCN, FSP)
|
||||||
|
HPT = (NPQ, VFQ)
|
||||||
|
KPF = (NVF, CDF)
|
||||||
|
PDH = (KQG, NKR)
|
||||||
|
PCV = (NJK, MDN)
|
||||||
|
XXG = (PGN, XDM)
|
||||||
|
MGC = (FXL, XKX)
|
||||||
|
QTL = (PDS, MHP)
|
||||||
|
JLB = (CQL, XRG)
|
||||||
|
RVN = (DVJ, NRN)
|
||||||
|
CTP = (FGM, MTJ)
|
||||||
|
RCC = (FGR, NVX)
|
||||||
|
CDF = (VHC, CSH)
|
||||||
|
NKL = (HBC, KVP)
|
||||||
|
PTV = (XLH, QLQ)
|
||||||
|
BBF = (QVC, CJQ)
|
||||||
|
TSJ = (VRT, GTK)
|
||||||
|
GCV = (SJR, SNZ)
|
||||||
|
NBF = (MBP, BNS)
|
||||||
|
PSD = (XNT, STS)
|
||||||
|
XLH = (LDT, STM)
|
||||||
|
NFK = (GQV, KFN)
|
||||||
|
VVX = (CVR, SPJ)
|
||||||
|
PNS = (VMX, PLS)
|
||||||
|
RBR = (HRG, SNS)
|
||||||
|
SBT = (SFJ, NFF)
|
||||||
|
DBT = (CCP, GLG)
|
||||||
|
RPN = (KNG, JHR)
|
||||||
|
XFJ = (HBT, XXG)
|
||||||
|
JSK = (LGJ, CMC)
|
||||||
|
CNT = (SHF, MGX)
|
||||||
|
HBJ = (FMQ, NXV)
|
||||||
|
VRX = (FJP, QVD)
|
||||||
|
RBS = (CNT, HMM)
|
||||||
|
STS = (RXQ, LJS)
|
||||||
|
DVB = (QJM, HFT)
|
||||||
|
JRX = (XLX, KHV)
|
||||||
|
RPJ = (QHG, QVV)
|
||||||
|
KDB = (GSS, CFM)
|
||||||
|
LHQ = (MFV, DKC)
|
||||||
|
RRX = (FKB, NBB)
|
||||||
|
HTJ = (GJK, DMM)
|
||||||
|
CDN = (VRD, LDP)
|
||||||
|
NFS = (RVN, NHG)
|
||||||
|
XJR = (GTJ, FDJ)
|
||||||
|
NCT = (DHL, KSX)
|
||||||
|
NHK = (CTV, PNS)
|
||||||
|
BGC = (KLN, BDB)
|
||||||
|
XJN = (MDN, NJK)
|
||||||
|
MFT = (RMT, QQQ)
|
||||||
|
RFL = (HJV, FPM)
|
||||||
|
XQS = (NLS, SCL)
|
||||||
|
BPH = (XCF, VVX)
|
||||||
|
SBG = (TSC, XMV)
|
||||||
|
LNV = (MGT, NKV)
|
||||||
|
QCH = (CKG, GSG)
|
||||||
|
JMF = (VNN, VJG)
|
||||||
|
LQF = (FNV, CNQ)
|
||||||
|
MVX = (HKV, BLG)
|
||||||
|
SQC = (VVP, TCD)
|
||||||
|
PGT = (DJL, KPF)
|
||||||
|
MFM = (BLG, HKV)
|
||||||
|
FMD = (VCL, FXV)
|
||||||
|
VRF = (BBF, CPG)
|
||||||
|
GTJ = (LKV, BKX)
|
||||||
|
XGV = (VRJ, DMD)
|
||||||
|
CTV = (PLS, VMX)
|
||||||
|
GLR = (RFJ, CJZ)
|
||||||
|
PXP = (JSC, KDD)
|
||||||
|
SRD = (SVG, DCR)
|
||||||
|
GGR = (FMT, JLV)
|
||||||
|
HSH = (RPK, LRP)
|
||||||
|
GXF = (QHC, TKN)
|
||||||
|
GBS = (TQS, HTL)
|
||||||
|
MHB = (HTL, TQS)
|
||||||
|
GTK = (DSS, FDN)
|
||||||
|
DJL = (CDF, NVF)
|
||||||
|
DPB = (VVQ, DCM)
|
||||||
|
DCG = (KFV, QCH)
|
||||||
|
FDX = (SRD, FRQ)
|
||||||
|
XKP = (QRT, RFR)
|
||||||
|
FVV = (GQC, TLB)
|
||||||
|
DMS = (VRD, LDP)
|
||||||
|
SVS = (KCC, CNC)
|
||||||
|
PRR = (SJF, BPT)
|
||||||
|
LFS = (RPN, BPM)
|
||||||
|
BLN = (XTH, LPV)
|
||||||
|
SPN = (NMK, NCD)
|
||||||
|
CMN = (KMC, VSM)
|
||||||
|
QHJ = (THL, VRF)
|
||||||
|
JGD = (DTK, SQC)
|
||||||
|
KCV = (QLN, LNV)
|
||||||
|
CRQ = (TSJ, BSR)
|
||||||
|
JFN = (RBX, DMR)
|
||||||
|
GJF = (NGH, JGS)
|
||||||
|
VSX = (RNT, QFN)
|
||||||
|
HQL = (VDF, GTB)
|
||||||
|
KMC = (HNF, RLF)
|
||||||
|
XSC = (TFG, XSG)
|
||||||
|
XDC = (STP, NBP)
|
||||||
|
PJK = (TCQ, PCL)
|
||||||
|
DSS = (JXD, FRS)
|
||||||
|
SMR = (QLS, QLS)
|
||||||
|
BMQ = (VRX, XMK)
|
||||||
|
FNB = (SNS, HRG)
|
||||||
|
BKX = (TFD, JVB)
|
9
23/elixir/inputs/day8_example1.txt
Normal file
9
23/elixir/inputs/day8_example1.txt
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
RL
|
||||||
|
|
||||||
|
AAA = (BBB, CCC)
|
||||||
|
BBB = (DDD, EEE)
|
||||||
|
CCC = (ZZZ, GGG)
|
||||||
|
DDD = (DDD, DDD)
|
||||||
|
EEE = (EEE, EEE)
|
||||||
|
GGG = (GGG, GGG)
|
||||||
|
ZZZ = (ZZZ, ZZZ)
|
5
23/elixir/inputs/day8_example2.txt
Normal file
5
23/elixir/inputs/day8_example2.txt
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
LLR
|
||||||
|
|
||||||
|
AAA = (BBB, BBB)
|
||||||
|
BBB = (AAA, ZZZ)
|
||||||
|
ZZZ = (ZZZ, ZZZ)
|
10
23/elixir/inputs/day8_example3.txt
Normal file
10
23/elixir/inputs/day8_example3.txt
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
LR
|
||||||
|
|
||||||
|
11A = (11B, XXX)
|
||||||
|
11B = (XXX, 11Z)
|
||||||
|
11Z = (11B, XXX)
|
||||||
|
22A = (22B, XXX)
|
||||||
|
22B = (22C, 22C)
|
||||||
|
22C = (22Z, 22Z)
|
||||||
|
22Z = (22B, 22B)
|
||||||
|
XXX = (XXX, XXX)
|
46
23/elixir/lib/day.ex
Normal file
46
23/elixir/lib/day.ex
Normal file
|
@ -0,0 +1,46 @@
|
||||||
|
defmodule AOC.Day do
|
||||||
|
defmacro __using__(opts) do
|
||||||
|
day = Keyword.get(opts, :day)
|
||||||
|
debug = Keyword.get(opts, :debug, false)
|
||||||
|
trim = Keyword.get(opts, :trim, true)
|
||||||
|
input_file = Keyword.get(opts, :input, nil)
|
||||||
|
|
||||||
|
quote do
|
||||||
|
def solve do
|
||||||
|
input =
|
||||||
|
AOC.Day.input_lines(unquote(day), unquote(trim), unquote(input_file))
|
||||||
|
|> parse_input()
|
||||||
|
|
||||||
|
if unquote(debug) do
|
||||||
|
IO.inspect(input)
|
||||||
|
end
|
||||||
|
|
||||||
|
part1_solution = part1(input)
|
||||||
|
IO.puts("Part 1: #{part1_solution}")
|
||||||
|
|
||||||
|
part2_solution = part2(input)
|
||||||
|
IO.puts("Part 2: #{part2_solution}")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def input_lines(day, trim, input_file) do
|
||||||
|
lines =
|
||||||
|
input_file_name(day, input_file)
|
||||||
|
|> File.stream!()
|
||||||
|
|
||||||
|
if trim do
|
||||||
|
Enum.map(lines, &String.trim/1)
|
||||||
|
else
|
||||||
|
lines
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def input_file_name(day, input_file) do
|
||||||
|
if input_file do
|
||||||
|
Path.join([File.cwd!(), "inputs", "day#{day}_#{input_file}.txt"])
|
||||||
|
else
|
||||||
|
Path.join([File.cwd!(), "inputs", "day#{day}.txt"])
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
170
23/elixir/lib/days/day7.ex
Normal file
170
23/elixir/lib/days/day7.ex
Normal file
|
@ -0,0 +1,170 @@
|
||||||
|
defmodule AOC.Day7 do
|
||||||
|
# use AOC.Day, day: 7, input: "example"
|
||||||
|
use AOC.Day, day: 7
|
||||||
|
|
||||||
|
@type_to_power %{
|
||||||
|
five_of_a_kind: 6,
|
||||||
|
four_of_a_kind: 5,
|
||||||
|
full_house: 4,
|
||||||
|
three_of_a_kind: 3,
|
||||||
|
two_pair: 2,
|
||||||
|
one_pair: 1,
|
||||||
|
high_card: 0
|
||||||
|
}
|
||||||
|
|
||||||
|
@card_to_power %{
|
||||||
|
?A => 14,
|
||||||
|
?K => 13,
|
||||||
|
?Q => 12,
|
||||||
|
?J => 11,
|
||||||
|
?T => 10,
|
||||||
|
?9 => 9,
|
||||||
|
?8 => 8,
|
||||||
|
?7 => 7,
|
||||||
|
?6 => 6,
|
||||||
|
?5 => 5,
|
||||||
|
?4 => 4,
|
||||||
|
?3 => 3,
|
||||||
|
?2 => 2
|
||||||
|
}
|
||||||
|
|
||||||
|
def parse_input(lines) do
|
||||||
|
lines
|
||||||
|
|> Enum.map(fn line ->
|
||||||
|
[hand, bid] = String.split(line, " ")
|
||||||
|
|
||||||
|
{hand, String.to_integer(bid)}
|
||||||
|
end)
|
||||||
|
end
|
||||||
|
|
||||||
|
def replace_jokers(hand, card) do
|
||||||
|
Enum.map(hand, fn
|
||||||
|
?J -> card
|
||||||
|
c -> c
|
||||||
|
end)
|
||||||
|
end
|
||||||
|
|
||||||
|
def best_joker_replacement(hand) do
|
||||||
|
freqs = Enum.frequencies(hand)
|
||||||
|
|> Enum.reject(fn {card, _count} -> card == ?J end)
|
||||||
|
|
||||||
|
cond do
|
||||||
|
Enum.any?(freqs, fn {_card, count} -> count == 4 end) ->
|
||||||
|
{card, _} = Enum.find(freqs, fn {_card, count} -> count == 4 end)
|
||||||
|
card
|
||||||
|
Enum.any?(freqs, fn {_card, count} -> count == 3 end) ->
|
||||||
|
{card, _} = Enum.find(freqs, fn {_card, count} -> count == 3 end)
|
||||||
|
card
|
||||||
|
Enum.any?(freqs, fn {_card, count} -> count == 2 end) ->
|
||||||
|
doubles = Enum.filter(freqs, fn {_card, count} -> count == 2 end)
|
||||||
|
if length(doubles) == 1 do
|
||||||
|
hd(doubles) |> elem(0)
|
||||||
|
else
|
||||||
|
[{double1, _}, {double2, _}] = doubles
|
||||||
|
if Map.fetch!(@card_to_power, double1) >= Map.fetch!(@card_to_power, double2) do
|
||||||
|
double1
|
||||||
|
else
|
||||||
|
double2
|
||||||
|
end
|
||||||
|
end
|
||||||
|
true ->
|
||||||
|
freqs
|
||||||
|
|> Enum.map(fn {card, _count} -> card end)
|
||||||
|
|> Enum.sort(fn card1, card2 ->
|
||||||
|
Map.fetch!(@card_to_power, card1) >= Map.fetch!(@card_to_power, card2)
|
||||||
|
end)
|
||||||
|
|> hd()
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def find_best_joker_configuration(hand) do
|
||||||
|
freqs = Enum.frequencies(hand)
|
||||||
|
joker_count = Map.get(freqs, ?J, 0)
|
||||||
|
|
||||||
|
case joker_count do
|
||||||
|
0 -> hand
|
||||||
|
5 -> 'AAAAA'
|
||||||
|
_ ->
|
||||||
|
joker_replacement = best_joker_replacement(hand)
|
||||||
|
|
||||||
|
replace_jokers(hand, joker_replacement)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def hand_to_type(hand, joker_rule) do
|
||||||
|
freqs = hand
|
||||||
|
|> String.to_charlist()
|
||||||
|
|> then(fn hand ->
|
||||||
|
if joker_rule do
|
||||||
|
find_best_joker_configuration(hand)
|
||||||
|
else
|
||||||
|
hand
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
|> Enum.frequencies()
|
||||||
|
|> Enum.map(fn {_k, v} -> v end)
|
||||||
|
|
||||||
|
cond do
|
||||||
|
Enum.member?(freqs, 5) -> :five_of_a_kind
|
||||||
|
Enum.member?(freqs, 4) -> :four_of_a_kind
|
||||||
|
Enum.member?(freqs, 3) and Enum.member?(freqs, 2) -> :full_house
|
||||||
|
Enum.member?(freqs, 3) -> :three_of_a_kind
|
||||||
|
Enum.count(freqs, & &1==2) == 2 -> :two_pair
|
||||||
|
Enum.member?(freqs, 2) -> :one_pair
|
||||||
|
true -> :high_card
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def compare_same_type_hands(hand1, hand2, joker_rule) do
|
||||||
|
hand1 = String.to_charlist(hand1)
|
||||||
|
hand2 = String.to_charlist(hand2)
|
||||||
|
|
||||||
|
Enum.zip(hand1, hand2)
|
||||||
|
|> compare_same_type_hands2(joker_rule)
|
||||||
|
end
|
||||||
|
|
||||||
|
def compare_same_type_hands2([], _), do: true
|
||||||
|
|
||||||
|
def compare_same_type_hands2([{card1, card2} | tl], joker_rule) do
|
||||||
|
if card1 == card2 do
|
||||||
|
compare_same_type_hands2(tl, joker_rule)
|
||||||
|
else
|
||||||
|
cond do
|
||||||
|
joker_rule and card1 == ?J -> false
|
||||||
|
joker_rule and card2 == ?J -> true
|
||||||
|
true -> Map.fetch!(@card_to_power, card1) >= Map.fetch!(@card_to_power, card2)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def sort_hands(hands, joker_rule \\ false) do
|
||||||
|
Enum.sort(hands, fn {hand1, _bid1}, {hand2, _bid2} ->
|
||||||
|
type1 = hand_to_type(hand1, joker_rule)
|
||||||
|
type2 = hand_to_type(hand2, joker_rule)
|
||||||
|
|
||||||
|
if type1 == type2 do
|
||||||
|
compare_same_type_hands(hand1, hand2, joker_rule)
|
||||||
|
else
|
||||||
|
Map.fetch!(@type_to_power, type1) >= Map.fetch!(@type_to_power, type2)
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
end
|
||||||
|
|
||||||
|
def part1(input) do
|
||||||
|
input
|
||||||
|
|> sort_hands()
|
||||||
|
|> Enum.reverse()
|
||||||
|
|> Enum.with_index(1)
|
||||||
|
|> Enum.map(fn {{_card, bid}, rank} -> rank * bid end)
|
||||||
|
|> Enum.sum()
|
||||||
|
end
|
||||||
|
|
||||||
|
def part2(input) do
|
||||||
|
input
|
||||||
|
|> sort_hands(true)
|
||||||
|
|> Enum.reverse()
|
||||||
|
|> Enum.with_index(1)
|
||||||
|
|> Enum.map(fn {{_card, bid}, rank} -> rank * bid end)
|
||||||
|
|> Enum.sum()
|
||||||
|
end
|
||||||
|
end
|
81
23/elixir/lib/days/day8.ex
Normal file
81
23/elixir/lib/days/day8.ex
Normal file
|
@ -0,0 +1,81 @@
|
||||||
|
defmodule AOC.Day8 do
|
||||||
|
# use AOC.Day, day: 8, input: "example1"
|
||||||
|
# use AOC.Day, day: 8, input: "example2"
|
||||||
|
# use AOC.Day, day: 8, input: "example3"
|
||||||
|
use AOC.Day, day: 8
|
||||||
|
|
||||||
|
@start "AAA"
|
||||||
|
@stop "ZZZ"
|
||||||
|
|
||||||
|
def parse_input([instructions, _ | nodes]) do
|
||||||
|
instructions = instructions |> String.to_charlist() |> Stream.cycle()
|
||||||
|
nodes = Enum.map(nodes, fn s ->
|
||||||
|
%{"id" => id, "left" => left, "right" => right} = Regex.named_captures(~r/^(?<id>[[:alnum:]]{3}) = \((?<left>[[:alnum:]]{3}), (?<right>[[:alnum:]]{3})\)$/, s)
|
||||||
|
|
||||||
|
{id, {left, right}}
|
||||||
|
end)
|
||||||
|
|> Enum.into(%{})
|
||||||
|
|
||||||
|
{instructions, nodes}
|
||||||
|
end
|
||||||
|
|
||||||
|
def reach_end(instructions, nodes) do
|
||||||
|
Enum.reduce_while(instructions, {@start, 0}, fn instruction, {current_node, step_count} ->
|
||||||
|
if current_node == @stop do
|
||||||
|
{:halt, step_count}
|
||||||
|
else
|
||||||
|
{left, right} = Map.fetch!(nodes, current_node)
|
||||||
|
next_node = case instruction do
|
||||||
|
?L -> left
|
||||||
|
?R -> right
|
||||||
|
end
|
||||||
|
|
||||||
|
{:cont, {next_node, step_count + 1}}
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
end
|
||||||
|
|
||||||
|
def part1({instructions, nodes}) do
|
||||||
|
reach_end(instructions, nodes)
|
||||||
|
end
|
||||||
|
|
||||||
|
def find_cycle(instructions, nodes, start) do
|
||||||
|
Enum.reduce_while(instructions, {start, 0, nil}, fn instruction, {current_node, step_count, last_end_count}->
|
||||||
|
if String.ends_with?(current_node, "Z") and last_end_count != nil do
|
||||||
|
{:halt, {last_end_count, step_count - last_end_count}}
|
||||||
|
else
|
||||||
|
last_end_count = if String.ends_with?(current_node, "Z"), do: step_count, else: last_end_count
|
||||||
|
{left, right} = Map.fetch!(nodes, current_node)
|
||||||
|
next_node = case instruction do
|
||||||
|
?L -> left
|
||||||
|
?R -> right
|
||||||
|
end
|
||||||
|
|
||||||
|
{:cont, {next_node, step_count + 1, last_end_count}}
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
end
|
||||||
|
|
||||||
|
def brute_force_find_cycle(cycles) do
|
||||||
|
Stream.repeatedly(fn -> nil end) |> Enum.reduce_while(cycles, fn _, cycles ->
|
||||||
|
all_ended = cycles |> Enum.map(&elem(&1, 0)) |> Enum.uniq() |> length() == 1
|
||||||
|
|
||||||
|
if all_ended do
|
||||||
|
{:halt, cycles |> hd() |> elem(0)}
|
||||||
|
else
|
||||||
|
[{count, cycle_count} | tl] = Enum.sort(cycles)
|
||||||
|
IO.inspect(count)
|
||||||
|
{:cont, [{count + cycle_count, cycle_count} | tl]}
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
end
|
||||||
|
|
||||||
|
def part2({instructions, nodes}) do
|
||||||
|
IO.puts("Use LCM for the following numbers :)")
|
||||||
|
Enum.filter(nodes, fn {k, _v} -> String.ends_with?(k, "A") end)
|
||||||
|
|> Enum.map(fn {k, _v} -> find_cycle(instructions, nodes, k) end)
|
||||||
|
|> Enum.map(&elem(&1, 0))
|
||||||
|
|> Enum.map(&Integer.to_string/1)
|
||||||
|
|> Enum.join(" ")
|
||||||
|
end
|
||||||
|
end
|
28
23/elixir/mix.exs
Normal file
28
23/elixir/mix.exs
Normal file
|
@ -0,0 +1,28 @@
|
||||||
|
defmodule AOC.MixProject do
|
||||||
|
use Mix.Project
|
||||||
|
|
||||||
|
def project do
|
||||||
|
[
|
||||||
|
app: :aoc,
|
||||||
|
version: "0.1.0",
|
||||||
|
elixir: "~> 1.15",
|
||||||
|
start_permanent: Mix.env() == :prod,
|
||||||
|
deps: deps()
|
||||||
|
]
|
||||||
|
end
|
||||||
|
|
||||||
|
# Run "mix help compile.app" to learn about applications.
|
||||||
|
def application do
|
||||||
|
[
|
||||||
|
extra_applications: [:logger]
|
||||||
|
]
|
||||||
|
end
|
||||||
|
|
||||||
|
# Run "mix help deps" to learn about dependencies.
|
||||||
|
defp deps do
|
||||||
|
[
|
||||||
|
# {:dep_from_hexpm, "~> 0.3.0"},
|
||||||
|
# {:dep_from_git, git: "https://github.com/elixir-lang/my_dep.git", tag: "0.1.0"}
|
||||||
|
]
|
||||||
|
end
|
||||||
|
end
|
3
23/elixir/mix.lock
Normal file
3
23/elixir/mix.lock
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
%{
|
||||||
|
"math": {:hex, :math, "0.7.0", "12af548c3892abf939a2e242216c3e7cbfb65b9b2fe0d872d05c6fb609f8127b", [:mix], [], "hexpm", "7987af97a0c6b58ad9db43eb5252a49fc1dfe1f6d98f17da9282e297f594ebc2"},
|
||||||
|
}
|
8
23/elixir/test/aoc_test.exs
Normal file
8
23/elixir/test/aoc_test.exs
Normal file
|
@ -0,0 +1,8 @@
|
||||||
|
defmodule AocTest do
|
||||||
|
use ExUnit.Case
|
||||||
|
doctest Aoc
|
||||||
|
|
||||||
|
test "greets the world" do
|
||||||
|
assert Aoc.hello() == :world
|
||||||
|
end
|
||||||
|
end
|
1
23/elixir/test/test_helper.exs
Normal file
1
23/elixir/test/test_helper.exs
Normal file
|
@ -0,0 +1 @@
|
||||||
|
ExUnit.start()
|
27
23/flake.lock
Normal file
27
23/flake.lock
Normal file
|
@ -0,0 +1,27 @@
|
||||||
|
{
|
||||||
|
"nodes": {
|
||||||
|
"nixpkgs": {
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1701693815,
|
||||||
|
"narHash": "sha256-7BkrXykVWfkn6+c1EhFA3ko4MLi3gVG0p9G96PNnKTM=",
|
||||||
|
"owner": "NixOS",
|
||||||
|
"repo": "nixpkgs",
|
||||||
|
"rev": "09ec6a0881e1a36c29d67497693a67a16f4da573",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "NixOS",
|
||||||
|
"ref": "nixpkgs-unstable",
|
||||||
|
"repo": "nixpkgs",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"root": {
|
||||||
|
"inputs": {
|
||||||
|
"nixpkgs": "nixpkgs"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"root": "root",
|
||||||
|
"version": 7
|
||||||
|
}
|
22
23/flake.nix
Normal file
22
23/flake.nix
Normal file
|
@ -0,0 +1,22 @@
|
||||||
|
{
|
||||||
|
description = "A Nix-flake-based Elixir development environment";
|
||||||
|
|
||||||
|
inputs.nixpkgs.url = "github:NixOS/nixpkgs/nixpkgs-unstable";
|
||||||
|
|
||||||
|
outputs = { self, nixpkgs }:
|
||||||
|
let
|
||||||
|
supportedSystems = [ "x86_64-linux" "aarch64-linux" "x86_64-darwin" "aarch64-darwin" ];
|
||||||
|
forEachSupportedSystem = f: nixpkgs.lib.genAttrs supportedSystems (system: f {
|
||||||
|
pkgs = import nixpkgs { inherit system; };
|
||||||
|
});
|
||||||
|
in
|
||||||
|
{
|
||||||
|
devShells = forEachSupportedSystem ({ pkgs }: {
|
||||||
|
default = pkgs.mkShell {
|
||||||
|
packages = (with pkgs; [ elixir_1_15 gnumake ]) ++
|
||||||
|
# Linux only
|
||||||
|
pkgs.lib.optionals (pkgs.stdenv.isLinux) (with pkgs; [ gigalixir inotify-tools libnotify ]);
|
||||||
|
};
|
||||||
|
});
|
||||||
|
};
|
||||||
|
}
|
Loading…
Reference in a new issue