This commit is contained in:
Moritz Hölting 2023-12-19 13:30:36 +01:00
parent bf349455b8
commit ff6ef36588
5 changed files with 1250 additions and 0 deletions

8
Cargo.lock generated
View File

@ -189,6 +189,14 @@ dependencies = [
"indoc", "indoc",
] ]
[[package]]
name = "day-19"
version = "0.0.0"
dependencies = [
"indoc",
"nom",
]
[[package]] [[package]]
name = "deprecate-until" name = "deprecate-until"
version = "0.1.1" version = "0.1.1"

12
day-19/Cargo.toml Normal file
View File

@ -0,0 +1,12 @@
[package]
name = "day-19"
version = "0.0.0"
edition = "2021"
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
[dependencies]
nom.workspace = true
[dev-dependencies]
indoc.workspace = true

724
day-19/src/bin/input.txt Normal file
View File

@ -0,0 +1,724 @@
mn{s<3661:A,s>3705:A,m<1698:R,A}
jcj{x<2501:R,s<516:R,A}
lm{s>1017:R,a>470:R,x>159:A,R}
hfm{x<661:gm,fck}
gvr{x<1627:jlj,R}
xd{a<3515:A,x<1086:R,R}
gms{a<3153:tbr,x<1274:hgz,mkg}
nsv{a<1742:R,x>142:R,dvh}
gz{x<1839:R,x>1848:A,R}
lc{m<2328:A,x>3513:A,R}
qc{x<1673:A,A}
ndl{s>3705:tr,a<3474:zr,x<1760:pl,R}
vfz{a<3535:tpv,R}
ld{x<2662:kdb,x>2851:A,m<3657:gt,A}
jlj{a>2672:A,R}
nn{a<2837:mm,x>3088:zj,m>1332:zf,tn}
kfq{m>3404:R,m>3071:A,nh}
xl{m<1669:A,s>3278:kdg,pm}
tz{x>2729:A,a>1540:A,x<2269:ttv,tkd}
gf{a<1839:jjv,s>3144:tfn,x<1424:gpj,ztz}
zf{x<2559:R,a<3507:bg,a>3813:A,xsf}
rkm{x<2920:qpl,hq}
sh{s<950:R,s<1280:R,a>1876:A,A}
zm{a<3311:R,s<3539:R,R}
fd{s<1125:A,m>1688:R,A}
qr{a>1507:A,x<236:R,R}
tvj{s<1336:gqp,tv}
frn{x<3485:vfx,vgj}
sf{x<2428:R,s>1024:A,s<385:R,R}
tx{a<835:R,s>3130:skj,ct}
mrf{x>1667:A,a<3699:R,R}
jkr{m<2927:kxc,a>2049:R,sh}
sc{s>1038:A,R}
tzc{m>2622:R,s<1490:R,A}
cml{s<2768:R,R}
rp{a<3056:R,A}
cmn{m<1877:A,x>103:A,mxg}
dsf{m>720:A,A}
zvv{s>1686:df,a<1613:fc,nnt}
sb{a<157:xhk,x<1408:qdf,m<1174:ff,zp}
xk{a>390:A,x<198:R,a>189:A,A}
jf{x>441:zvv,a>2404:jqg,a>1410:bvc,mb}
ktt{a>231:R,R}
lvj{x>3711:zpn,x<3392:tlf,R}
fsj{x>3517:A,A}
vn{x>1525:jn,x<1345:zjl,s<1431:vh,gf}
nv{s>3581:R,s<3340:A,A}
rf{m>2639:A,s>3257:zm,jg}
rh{a>813:R,s>3042:A,s>2781:A,R}
dq{x<2671:rj,qz}
qpl{s<3540:mv,A}
mz{a<2856:R,a>3430:pvc,x<2330:ftt,pg}
ggm{s<2962:A,x>2214:A,A}
vf{s<349:R,x>1227:R,a<705:A,A}
mrc{a>3426:A,R}
zms{a>3329:A,R}
lf{m>2687:A,x<1481:A,m<2144:R,R}
kdb{s<3016:R,A}
ftv{m>2340:R,a<623:A,m<1159:A,A}
gph{x<123:A,R}
rhl{s>251:bc,m>3504:vfr,a<2788:hzr,zn}
kd{x>243:dc,m<3343:dvn,mjb}
fdf{m<1679:kdk,m>2987:R,gc}
ms{x<3198:R,A}
ph{m<1356:R,R}
smf{m<1642:A,m>2204:R,a>250:A,A}
crv{m>1119:vg,a>3589:djp,hqh}
cps{a<982:R,x>3117:R,x<2335:A,R}
pqh{s>328:A,m>3037:R,x>1636:A,A}
br{a>981:A,s<3008:R,A}
zdq{s>346:R,m>1682:R,a>2849:A,R}
tbr{s<2338:zfh,m>1880:ghf,nzj}
gmm{x<3087:A,A}
lzz{m<3111:ndn,fm}
pqm{a>3473:fr,R}
pmh{m<984:A,A}
dgt{s>1976:R,a>2943:A,m<250:A,A}
jvx{m<3147:R,s<322:R,A}
vhs{s>3174:dxt,zv}
dk{a>2545:A,x<2584:R,s<3184:A,R}
kkq{m<2016:R,x<1586:A,a<419:A,R}
ccn{x>1109:xjj,rb}
fsz{m<3908:R,m<3950:sml,a>3520:R,tcq}
lcr{m>849:R,a>1453:R,m<764:A,R}
vjc{a>2523:R,s>108:R,m>3085:R,R}
rz{x>1108:A,m>2183:R,m>1020:R,R}
xhk{x<1562:gkk,R}
lt{x>247:A,x<218:R,R}
sq{m<2979:xpl,s>1347:lx,m>3340:nsv,pf}
tt{x<1676:R,R}
xrp{x<177:rh,spb}
zvj{a<3736:A,s>168:R,m>520:R,A}
sth{x>1719:nbq,m>2754:lpz,s<346:cpt,kvp}
kl{x>812:A,tqn}
nzj{a<2917:zkq,a<2997:vkp,a>3090:tfb,fg}
gnt{x>1725:R,A}
tmh{m<1627:A,m<1805:A,a<756:R,A}
ttv{m>1339:A,A}
hhq{m<1659:jpj,x>1806:lh,ntr}
pk{a>2233:R,A}
lv{a<543:znq,a<825:A,x<3669:R,A}
bk{s>659:A,vf}
sj{x>1645:R,a>3807:nlm,A}
fm{a>3743:lq,s<2464:jl,s>3039:mhs,ts}
nbq{a<3565:R,hk}
ct{a<1076:A,s<2510:R,x>89:A,A}
znq{s>872:R,s>389:R,x<3462:A,R}
vkp{m>791:R,a<2954:mj,rl}
sjj{m>3095:R,s<922:R,R}
tqn{x<632:R,A}
xxd{a<937:cm,m<689:A,lcr}
gnv{s>881:R,x>1689:A,A}
cq{m>1527:A,x>369:R,A}
tp{m>3533:R,m<3498:A,A}
bl{x>1747:A,zvk}
rb{s>2690:xd,gp}
tq{x>99:A,s>780:A,gv}
tn{a>3559:lnp,m>860:dj,x>2439:xv,ghz}
fxp{x<3712:ccp,s<904:ss,shj}
rk{s>1884:kq,m>3604:lv,s>1153:fq,cdr}
hsz{a>1328:R,A}
qxn{x>1698:hhq,x<1660:sjv,tb}
cm{s>1819:A,x<2244:R,A}
gfq{s<2146:tq,a>1886:cmn,a>1662:pt,kmq}
ft{s<725:rhl,lff}
rc{s<102:R,R}
ss{x<3880:A,x>3942:R,s>475:A,A}
ztz{m>1355:lf,R}
pgd{a<3436:A,x<926:nhv,x>995:xmv,A}
tr{s<3868:A,x>1733:R,s>3944:A,R}
xv{a>3190:R,A}
hgr{m<3265:A,m<3624:A,m<3842:R,A}
qxm{s<2975:mlh,m>1465:lrh,R}
fq{m>3473:tp,m>3434:A,s>1511:A,A}
hk{a>3745:A,x>1782:R,x>1749:R,A}
gst{x<1764:A,s<2078:R,s<2479:R,A}
fqp{a<2237:mr,a<2303:R,A}
fmp{a<637:R,m>2055:R,R}
jjv{a<1298:bmj,x<1415:cd,A}
cl{x>327:R,a<662:R,A}
cvn{s<2271:R,x>1760:qx,R}
fqr{s>2475:lzt,a>3662:R,R}
jg{a>3308:A,a>3257:R,a<3243:A,R}
vm{x>1608:A,s>2267:R,R}
zzc{s<1510:xsq,s<2530:nk,xrp}
pg{x>2454:R,a<3237:A,A}
jt{a<2036:A,x>3568:R,R}
kp{s<3254:xcn,m<2368:xcv,A}
rkx{a<3478:R,x>1142:A,a>3606:R,A}
kqs{x<1646:R,a>3810:tdp,m<776:mrf,A}
mk{x<204:R,A}
mt{a<512:R,a>675:R,a<618:R,A}
cbq{a<3691:R,R}
lbg{x>1685:fll,x<1633:vm,s<2084:R,R}
nrd{x>3246:A,x>2349:R,smf}
zvk{s>3078:R,s>2987:R,a>3465:A,R}
mjb{m>3647:A,a<883:pz,mp}
db{a>1922:fqp,m>469:kqc,qj}
qbp{m<1961:A,s<3848:sp,m>2251:R,mfz}
cgg{s>166:A,R}
vfr{m>3672:R,x<3116:rc,R}
ff{a>278:jp,s>2093:ktt,m>425:R,R}
qtf{a<798:A,R}
kz{x<169:tx,m>726:fj,qh}
vtk{a<3490:A,R}
bjc{s>1024:hnt,R}
nr{x<217:A,x<248:R,A}
bvc{x>285:ths,m>2387:sq,m<1094:db,gfq}
tcq{x>1748:R,x<1691:A,R}
zd{m>3496:R,m<3436:R,A}
gl{s<3344:R,s>3741:R,m<3609:R,R}
djm{m<1932:A,A}
jbv{a>1587:A,m>698:R,s<2324:R,A}
rzh{s>2629:A,a<1890:A,x<1182:A,A}
spb{s<3380:R,A}
lcf{s>1018:A,a>721:R,fmp}
mfz{s<3933:R,R}
kxn{x>2596:R,m>3047:R,a>2293:R,A}
cnh{s<2989:R,s<3391:R,a>1818:A,R}
jqg{s<2459:hzs,vhs}
lnp{s<1688:R,s>2271:A,s>1968:R,R}
lpz{a>3507:pqh,m>2945:A,zms}
pxm{a>2777:R,a>2129:R,m<412:A,R}
ndn{a>3628:sz,m>2877:kkt,gmm}
pf{s<504:jvx,m>3148:mh,m>3049:sjj,A}
tbx{s>3338:R,x>2728:A,x<2208:A,R}
cjh{m>3506:A,m<3434:A,A}
tl{x>2730:qtf,xxd}
qs{a>2177:A,a>1953:R,a<1811:A,R}
vsh{a>3395:mf,tg}
gkk{s<2039:R,a>94:R,R}
dg{s<3005:R,A}
sjv{a<2806:gvr,m<1615:mkc,m>2717:jvk,fn}
rjl{s<1499:A,a<517:A,m>1643:R,R}
bdb{x>2480:R,R}
lz{m<2165:A,m>2321:R,s<2840:R,R}
fkh{a<3538:hvr,tkl}
ljp{s>1134:bzg,kkq}
jp{a<325:R,a>333:R,a>330:A,R}
qk{a>3005:R,m<2895:R,R}
tqs{x>1231:A,A}
jd{x<720:A,A}
pmf{x>1307:R,R}
jx{m>3503:R,R}
xcv{x>1264:A,s>3562:A,R}
ffc{s>1660:dl,x<1559:dqk,x>1746:mmg,btt}
vkk{m<3367:qqx,x<3176:tqb,a<1238:rk,dr}
kdf{s>2631:R,R}
dkq{m<2342:A,x<836:A,x<910:A,A}
zqt{x<1765:R,x>1814:R,R}
cd{a<1640:A,s<2718:A,A}
xmv{a>3790:A,x<1023:R,A}
kdg{x>1759:A,m>2736:R,R}
xvt{a>3623:nx,A}
trl{x>770:A,m>2294:jh,hsz}
zr{x>1726:A,R}
vq{m<2151:R,s>837:A,bm}
zbr{a>3598:qdp,vsh}
ts{x>2576:A,x<2156:A,R}
xb{x<1323:kdz,s<2020:A,mvt}
vr{a<3735:qdr,x>1746:dst,s<1998:pjn,A}
btt{m<2603:hg,a>189:dct,bhr}
zz{m<2544:R,a<2964:A,s<1093:R,A}
zv{x>188:jxt,x<78:hp,R}
kqc{a>1656:A,x<181:R,a<1532:R,jbv}
ksl{x>1716:A,R}
lrh{x<1401:A,a>789:R,A}
qj{s<1997:A,nzf}
nsp{x<355:R,A}
jz{a<3613:pp,lk}
fck{s>2679:A,A}
vfx{x>3110:A,m<3382:R,a<3064:R,A}
vl{s<2867:R,x<3226:tbx,m<143:fsj,A}
fdq{a<2937:R,m>1742:A,m>699:A,R}
djp{s>588:R,s<375:zvj,R}
hg{s<941:R,a<158:R,s>1333:R,A}
nhl{a<842:jdc,m>1845:vq,a<1264:tk,tz}
skj{x<80:A,R}
nnt{m<1816:zrl,a<2781:jkr,s>660:hr,kl}
knb{a>1181:qc,A}
kvp{m<2615:xc,a<3542:xvf,A}
mkg{x>1475:fgc,vxx}
ghz{s<1263:A,a>3172:R,R}
qdr{m>2023:A,x<1754:A,R}
qhd{x<255:R,a>1141:R,R}
dqk{m>3212:R,s>1016:A,pls}
rfx{s<2820:A,A}
np{x>1370:lcf,bk}
gtj{x<196:R,s>1193:A,s<927:R,R}
cc{s>2568:R,R}
zt{a>2797:R,s>2797:R,a<2702:R,A}
vxx{x>1390:xvt,a<3702:kc,xb}
rvf{m<3175:R,m<3678:gg,dk}
tg{m>3363:R,m<2905:A,m>3162:A,R}
hb{x<3265:A,m<2201:A,s>3582:A,lc}
rtx{a<714:lm,s>1097:qhd,R}
pls{m>2456:A,s>426:R,m>2194:R,A}
hrv{a<3514:R,A}
vh{x<1421:cff,kf}
ds{s>2587:rvf,kfq}
cff{a<1614:jxg,nc}
bps{m<507:rtx,jq}
zjl{m<2130:hxr,s<1643:zmk,x<1224:rx,fx}
jxt{s<2705:A,R}
tv{a>3495:tqs,m<1901:A,zck}
gg{x>3270:A,a>2494:A,R}
qv{s>1679:R,R}
dt{a>2086:R,s>126:R,R}
tfz{x<1427:R,a>497:R,x>1670:R,R}
tpn{s>1975:R,s<1639:R,a<2071:R,A}
bhr{s>992:A,x>1683:A,m<3407:A,A}
nx{s>2469:R,a<3826:R,A}
mvt{a>3819:R,s<2734:A,x<1357:A,A}
qrv{s<2662:cnk,s>3212:A,m<2188:R,A}
gp{x>1091:A,m>2260:A,R}
xsq{m<2092:tmh,s>766:gtj,a<651:xk,A}
xnx{s>1313:R,R}
nhv{s>2972:A,A}
gpj{a>2285:R,s>2372:R,tpn}
bmj{m<1925:R,a>1048:A,R}
rm{s>1123:A,A}
rj{m<1592:ggm,x>2353:fs,s>2993:A,A}
dm{a<3662:rz,x<1113:R,x>1142:xtp,xlf}
tj{a>3586:mk,a<3287:mht,R}
kc{m>2340:hrv,s>1715:A,R}
fdt{m<1287:R,a>3344:R,R}
pvc{s<1234:R,m>3049:R,a<3802:R,A}
zp{a>258:R,x>1647:A,jj}
qn{m<1271:A,A}
tgj{a<1770:R,A}
mj{s<2970:R,x<1353:A,A}
bh{s<2666:nn,a>2622:dlf,m<1714:vlj,rkm}
bc{x>2604:jx,x>2331:jcj,a<2724:A,R}
hh{a<3215:qxn,s<1521:lr,s<2817:jz,fkh}
xcn{m<1831:R,x>1275:A,m>2825:A,A}
dr{s<1876:fxp,rhj}
nlm{s<3380:A,s<3708:R,R}
fzl{x>187:R,a<1934:R,A}
ths{s<1404:bp,fms}
mht{s>1243:A,A}
dlg{m>871:A,a>1668:A,R}
vxz{s>126:R,a<3458:R,a<3681:A,A}
bm{x<2634:A,R}
cdr{x>3527:zd,cb}
sp{a<1106:A,x>2784:A,s>3808:A,A}
lg{s<901:jb,s>1546:rn,a>482:fd,ljp}
qdf{s<1591:R,a<256:A,lvs}
xz{m<1481:cps,a>972:lcp,s<3564:A,mn}
lcp{x<2839:R,a>1232:A,x>3245:R,R}
kxc{x>774:R,A}
mv{s>3013:A,x>2298:A,s<2800:R,A}
rx{m<3079:mrk,a>1474:R,R}
bbm{m<3755:R,R}
hd{x<1703:bbm,m>3786:cbq,m<3748:R,R}
mb{m>2654:kd,m>1299:zzc,s<1993:bps,kz}
fvx{s>864:dm,x>1121:jbq,vfz}
bp{s>707:nsp,cq}
gb{a<3053:R,a<3115:R,A}
tkl{x>1688:xl,m>1977:sj,kqs}
xpl{a<1817:tzc,x>169:nr,a>2176:R,R}
gm{x<546:R,s>3053:A,a>3376:A,A}
hx{s>2045:vl,x>3142:lvj,pbp}
fc{a<1041:fv,trl}
gqp{a<3558:xcj,s<462:R,s>988:R,R}
mkc{m<632:dgt,m>995:gb,s<2449:R,A}
hp{s<2877:R,m>1762:R,R}
shj{x<3833:A,a>1667:A,s<1535:R,A}
fv{s<624:ftv,s>1101:A,a>691:A,R}
rkt{m<2656:R,R}
jbq{m>1513:A,s<563:A,hzq}
sml{m>3925:R,a>3709:A,a>3380:A,A}
xtp{m<2367:A,A}
pl{x>1653:R,R}
gt{a>700:R,A}
vg{m>1872:gnv,s>989:zqt,gh}
jpj{x<1767:gnt,A}
kmq{x>151:qr,m<1575:A,s>3253:cmd,A}
hzs{m>2250:sl,a>3055:tj,dxk}
in{x>1863:xq,gx}
dj{x<2303:A,x>2600:R,A}
lh{a<2846:A,m>2459:ptx,s>1865:lz,gz}
pr{m<3049:R,R}
dz{a<713:nrd,qbp}
mrk{m>2755:A,A}
ks{x>2852:R,zlt}
tkd{x>2536:A,R}
gx{x<1056:jf,a<2531:xxv,x>1588:hh,gms}
nzf{m>296:R,a<1691:A,R}
tqb{x<2363:pb,s>2261:ld,ks}
fx{m<3263:cnh,a<1482:A,A}
cnz{a>2636:A,A}
rqc{s<2857:A,R}
tpv{s<353:R,s<530:R,s<748:A,A}
zn{m>2957:vxz,cgg}
ptx{m>3400:A,x<1841:A,s>2075:R,A}
nk{s<2082:A,s>2236:R,A}
nc{s>803:R,a<2184:A,m>1658:A,A}
mhg{a<1907:A,m>740:A,m>407:A,R}
hzr{a>2332:vjc,a<2223:dt,kxn}
fg{m>1182:rp,m<530:A,m<823:A,R}
xlf{m>1757:R,a>3792:A,A}
qz{a<1148:R,a<1473:rd,x<3400:A,R}
vvs{m<1832:gst,x>1728:xkp,x>1651:zgj,R}
px{m>1343:R,A}
cg{a>2956:R,R}
xc{m>2487:A,A}
zfh{s<1106:srk,djm}
gc{a>3568:R,R}
mf{m>3369:A,m>3034:R,s<1159:A,R}
zck{m<2862:R,a<3295:R,R}
mh{s>829:A,s<690:R,A}
zdt{m<3707:vtk,m>3837:fsz,hd}
zkq{s<3264:rqc,R}
mxg{m>2191:A,s>2784:R,a>2067:R,R}
rr{a>3120:A,a>3101:R,x<1787:R,R}
qrl{a>2765:rkt,cnz}
lvs{x>1273:A,R}
cz{s>3104:R,a<1812:A,R}
lr{m<2420:crv,s>569:zbr,m<3184:sth,zdt}
ghf{x<1244:vbq,zk}
hzq{s<705:A,a<3489:A,A}
hxr{a<1675:R,a<2007:rzh,pk}
jvk{m>3317:A,s>1927:R,a>2952:R,szx}
mp{s<2457:R,s<3073:R,A}
tk{a>1095:fsb,R}
hn{a>2033:R,s<2640:A,m<1587:dlg,cz}
nh{m>2777:R,a>2450:A,x<3023:R,A}
lq{m<3533:A,s>2891:A,s>1978:R,R}
srk{s<564:zdq,A}
jxg{x<1373:A,m>2224:A,a<1304:A,A}
dxk{x<291:gph,R}
pt{x<188:tgj,m<1898:lt,s<2956:lgr,A}
lff{x>2601:frn,m<3372:mz,bjc}
tb{s<1696:xm,x>1678:qrl,x<1672:rdg,hzb}
lzt{m>1509:R,x>1505:A,m<537:R,A}
rq{a>1733:bh,m>996:qm,bd}
tlf{x<3232:A,m<228:R,m>301:R,R}
ml{s<3209:dzn,cr}
qqx{x>3015:qv,pr}
fs{s<3056:A,a>1067:A,A}
kf{s<815:A,a>1938:R,nm}
pz{x<109:A,a<462:A,m>3455:R,R}
nm{s>1143:A,a>1477:A,a>1181:R,A}
kdk{s<1608:R,a<3613:R,A}
xxv{a>872:vn,a>348:vk,dnq}
qx{s>2554:R,a>3943:A,A}
lgr{m<2196:R,R}
zk{m>2885:qt,s>3306:A,zt}
mm{a>2237:kv,x>2878:sc,m<1672:mhg,qp}
dnq{m>1899:ffc,sb}
ntr{a<2924:R,x<1760:mqf,a<3066:A,rr}
qm{s<2346:nhl,s<3437:dq,s<3753:dtt,dz}
bd{m<353:hx,tl}
fj{x>267:cl,s>3135:A,a>576:A,A}
cmd{a<1530:R,a<1617:R,R}
cpt{m>2566:R,x<1640:A,R}
zgj{s>1980:A,a<3427:R,A}
hvr{a<3425:rf,s<3426:bl,ndl}
jq{a<541:pmh,a<926:R,A}
ccp{m>3658:R,m>3555:A,A}
dvn{s>1767:R,a>522:A,R}
vvm{s>2965:A,A}
hgz{x>1160:tvj,s<1847:fvx,ccn}
jfl{a>629:qxm,x<1525:kp,a>532:ksl,qrv}
xq{m>2576:ffn,rq}
hr{a<3242:zz,m>2967:rtl,dkq}
jl{s>1964:R,R}
pp{m>2274:mrc,m<1108:lbg,m>1498:vvs,thr}
qt{m>3464:A,R}
rtl{m>3647:A,R}
jb{x<1581:pmf,m>2361:A,R}
dl{a<118:R,a>235:R,dg}
mr{s<2296:A,A}
zpn{s>1287:R,A}
zmk{m>3101:R,a>1862:R,A}
fll{m>559:R,R}
dlf{x>3210:dcg,pqm}
jj{s>1976:R,s<735:A,R}
xjj{a<3697:rkx,A}
pjn{a<3809:A,x<1689:A,a>3843:R,R}
gzx{m>3247:A,R}
vk{s>1922:jfl,a<588:lg,np}
fms{a<1845:rfx,s<2483:dx,a<2108:R,R}
mmg{s<872:A,x<1817:R,A}
lx{m<3512:cml,s>2892:R,fzl}
hq{s>3232:qs,m>2220:jt,a>2077:A,R}
dtt{m>1833:hb,xz}
vlj{a<2140:ml,a>2383:dgd,jm}
cr{a<1904:R,m>976:A,s>3736:R,R}
lnn{a<3317:ds,lzz}
dc{x<363:A,s>1439:hgr,m>3285:A,kbg}
jm{s>3456:A,s>2930:A,x>2786:ms,R}
vbx{a>3526:R,x<1759:A,A}
fgc{x<1525:fqr,fdf}
xsf{a>3670:A,x<2866:A,A}
lgf{s>352:A,R}
mqf{x<1738:R,R}
bdx{a>1373:R,R}
pm{s>3040:R,s>2959:R,x<1767:R,A}
dgd{m<919:xs,x>3141:ph,R}
kv{m>1662:R,R}
dvh{a>2032:R,a<1895:R,s<700:R,R}
cb{m<3466:R,x<3395:A,R}
mlh{s>2509:R,A}
df{a<2667:sm,x>794:pgd,hfm}
gh{x>1717:A,a>3671:A,s>547:A,A}
dxt{m<2555:R,A}
pb{s<2328:R,a<1018:gl,m>3696:bdx,A}
dzn{x>2899:A,a>1917:A,R}
cnk{x<1638:R,s<2322:A,x<1784:A,A}
rdg{x>1665:R,x<1662:R,R}
xkp{x<1813:R,a<3429:A,A}
vgj{x<3716:R,R}
rl{m>294:A,R}
tfb{s<3203:R,x<1370:R,s<3645:A,vs}
kq{m>3723:R,a<811:mt,br}
ck{m>2095:A,a<2991:A,A}
qdp{a<3818:gzx,A}
mhs{m>3601:R,m<3327:R,x>2985:A,A}
hnt{s<1237:A,x<2124:A,A}
qh{x>294:A,vvm}
kdz{a>3816:A,s<2322:R,s<2913:R,A}
xm{s<626:fdq,a<2958:xnx,s<1218:R,R}
jh{s<911:A,m>3035:R,x>622:A,A}
bzg{s<1344:R,A}
dct{x<1655:R,s>598:A,m>3271:R,A}
pbp{m<220:sf,m>275:bdb,s<889:R,A}
thr{a<3473:fdt,s<2291:px,x>1738:qn,A}
rd{x>3336:R,a>1276:A,a<1192:A,R}
jdc{x>2745:rjl,A}
sz{s<2641:A,m<2766:R,s>3431:A,R}
gv{x>40:R,a<2021:R,m<1655:A,A}
tdp{s>3500:A,a<3931:R,A}
xs{x<3279:R,x>3661:A,A}
kbg{s>778:A,A}
jn{a<1479:knb,hn}
szx{s>690:A,m<2955:R,x<1617:A,A}
zlt{x<2589:R,a>907:A,a<376:R,R}
fsb{s>1096:A,m>1470:A,s<415:R,R}
ffn{a<2017:vkk,s<1515:ft,lnn}
bg{m>1789:A,m<1559:R,x<2819:A,R}
sl{m>3167:A,m>2576:qk,A}
xvf{m<2675:A,a>3418:A,x<1671:R,R}
fr{a>3763:R,m<1443:A,R}
kkt{a>3472:A,a>3382:A,s>2345:A,A}
xcj{s<881:A,R}
hqh{m<502:R,s>575:R,a<3429:lgf,vbx}
tfn{x<1411:R,A}
dst{a>3822:R,m>1505:A,R}
ftt{s>1217:A,a<3222:R,A}
rhj{s<3065:A,m<3720:cjh,nv}
rn{m<2545:R,a<457:R,a>540:R,tfz}
zj{m>1037:A,m>471:dsf,x>3609:R,rm}
fn{x<1616:ck,x<1634:R,R}
dcg{x<3587:R,A}
vbq{s<3443:R,R}
vs{s>3829:A,x>1496:A,m>721:R,R}
zrl{m>712:jd,pxm}
lk{a>3868:cvn,vr}
sm{x<753:cc,kdf}
dx{x<387:R,x>406:R,s<1958:A,R}
qp{s>1439:R,x<2270:R,x<2617:R,A}
hzb{m<2387:cg,tt}
{x=1353,m=3037,a=1714,s=2238}
{x=608,m=1974,a=1157,s=1316}
{x=1225,m=1440,a=80,s=1364}
{x=4,m=1245,a=948,s=147}
{x=30,m=2538,a=1716,s=823}
{x=626,m=128,a=1042,s=519}
{x=182,m=87,a=1114,s=123}
{x=3097,m=2262,a=60,s=505}
{x=700,m=1844,a=30,s=185}
{x=88,m=2157,a=39,s=1966}
{x=703,m=305,a=704,s=1759}
{x=400,m=1034,a=1947,s=1104}
{x=27,m=1959,a=87,s=1404}
{x=1654,m=351,a=1498,s=605}
{x=546,m=629,a=1120,s=776}
{x=1467,m=1402,a=2819,s=652}
{x=395,m=710,a=37,s=426}
{x=165,m=986,a=3316,s=3628}
{x=119,m=2580,a=477,s=1134}
{x=4,m=44,a=760,s=216}
{x=1633,m=3445,a=1494,s=1396}
{x=670,m=1082,a=708,s=290}
{x=2566,m=2148,a=99,s=3038}
{x=107,m=1631,a=2,s=293}
{x=2292,m=984,a=3360,s=124}
{x=2624,m=501,a=1111,s=1114}
{x=1217,m=1508,a=2880,s=1744}
{x=1705,m=623,a=271,s=3}
{x=3043,m=25,a=2091,s=1193}
{x=1566,m=53,a=418,s=6}
{x=1438,m=255,a=1726,s=1265}
{x=77,m=326,a=486,s=795}
{x=31,m=836,a=596,s=327}
{x=477,m=1056,a=1680,s=2268}
{x=898,m=647,a=66,s=244}
{x=3627,m=2071,a=96,s=625}
{x=1149,m=1690,a=79,s=237}
{x=710,m=847,a=2859,s=618}
{x=20,m=1793,a=1189,s=207}
{x=10,m=337,a=1006,s=127}
{x=184,m=113,a=945,s=1385}
{x=913,m=448,a=458,s=384}
{x=1236,m=181,a=1480,s=273}
{x=3386,m=4,a=297,s=2045}
{x=106,m=846,a=1723,s=415}
{x=1888,m=1035,a=375,s=17}
{x=496,m=3286,a=1123,s=225}
{x=1322,m=104,a=670,s=584}
{x=544,m=293,a=14,s=350}
{x=3419,m=469,a=3627,s=594}
{x=447,m=78,a=518,s=479}
{x=2602,m=700,a=536,s=1356}
{x=956,m=95,a=1599,s=492}
{x=1,m=1709,a=117,s=141}
{x=83,m=1970,a=143,s=411}
{x=479,m=1316,a=1129,s=953}
{x=1389,m=1084,a=1747,s=1196}
{x=792,m=1456,a=3617,s=278}
{x=306,m=2611,a=1080,s=601}
{x=310,m=118,a=2829,s=2395}
{x=249,m=295,a=1027,s=1016}
{x=117,m=793,a=935,s=2867}
{x=266,m=32,a=164,s=286}
{x=71,m=1881,a=474,s=223}
{x=519,m=1971,a=390,s=713}
{x=530,m=1052,a=826,s=732}
{x=2082,m=3165,a=1378,s=2921}
{x=281,m=2172,a=687,s=1294}
{x=822,m=217,a=322,s=540}
{x=53,m=2695,a=3592,s=63}
{x=323,m=219,a=1463,s=65}
{x=41,m=248,a=774,s=1178}
{x=641,m=155,a=1850,s=53}
{x=1305,m=253,a=2104,s=404}
{x=2832,m=2439,a=893,s=996}
{x=3936,m=107,a=419,s=221}
{x=1350,m=2275,a=42,s=856}
{x=1405,m=360,a=1360,s=1224}
{x=1558,m=488,a=2624,s=1172}
{x=2773,m=515,a=1302,s=115}
{x=240,m=1969,a=1655,s=164}
{x=105,m=2654,a=709,s=2241}
{x=140,m=1403,a=299,s=145}
{x=1173,m=747,a=121,s=1231}
{x=826,m=2987,a=931,s=658}
{x=752,m=8,a=3101,s=129}
{x=1980,m=131,a=1929,s=2282}
{x=433,m=2,a=1493,s=1029}
{x=104,m=317,a=856,s=1780}
{x=116,m=2665,a=584,s=835}
{x=1988,m=283,a=2314,s=569}
{x=270,m=381,a=308,s=369}
{x=1058,m=360,a=75,s=872}
{x=359,m=906,a=1329,s=144}
{x=1920,m=533,a=1340,s=63}
{x=713,m=133,a=332,s=2928}
{x=345,m=2121,a=493,s=1699}
{x=177,m=711,a=86,s=601}
{x=1141,m=890,a=2322,s=3109}
{x=52,m=189,a=1216,s=2289}
{x=671,m=13,a=14,s=783}
{x=2194,m=312,a=343,s=1076}
{x=895,m=768,a=634,s=679}
{x=294,m=2318,a=1300,s=434}
{x=72,m=59,a=1540,s=166}
{x=248,m=2740,a=183,s=1876}
{x=1749,m=525,a=1176,s=113}
{x=1446,m=3065,a=223,s=932}
{x=1863,m=448,a=2911,s=608}
{x=245,m=1250,a=19,s=696}
{x=61,m=746,a=2942,s=113}
{x=214,m=107,a=1544,s=3227}
{x=393,m=1357,a=68,s=264}
{x=16,m=1376,a=180,s=329}
{x=28,m=793,a=234,s=219}
{x=382,m=2129,a=1963,s=1348}
{x=280,m=374,a=1653,s=961}
{x=1252,m=352,a=824,s=116}
{x=133,m=192,a=970,s=735}
{x=940,m=828,a=102,s=1516}
{x=993,m=2165,a=27,s=379}
{x=514,m=257,a=1094,s=1268}
{x=317,m=3266,a=2567,s=754}
{x=2893,m=3393,a=121,s=1018}
{x=978,m=2629,a=68,s=566}
{x=436,m=225,a=1646,s=1042}
{x=2798,m=2503,a=697,s=79}
{x=160,m=800,a=189,s=2042}
{x=80,m=559,a=1355,s=557}
{x=26,m=774,a=75,s=992}
{x=252,m=1901,a=1329,s=2136}
{x=457,m=15,a=289,s=311}
{x=403,m=1377,a=399,s=1762}
{x=220,m=246,a=367,s=2416}
{x=172,m=137,a=1004,s=843}
{x=200,m=1046,a=343,s=743}
{x=220,m=80,a=389,s=683}
{x=3094,m=1241,a=71,s=1872}
{x=92,m=723,a=4,s=636}
{x=548,m=422,a=16,s=185}
{x=530,m=3498,a=619,s=399}
{x=2100,m=160,a=1497,s=1222}
{x=723,m=70,a=11,s=1267}
{x=85,m=240,a=545,s=2591}
{x=1937,m=1470,a=100,s=2233}
{x=141,m=100,a=2327,s=484}
{x=48,m=1999,a=346,s=692}
{x=81,m=728,a=777,s=1003}
{x=135,m=1121,a=1698,s=46}
{x=2398,m=720,a=222,s=2291}
{x=798,m=523,a=3130,s=834}
{x=934,m=398,a=58,s=3629}
{x=365,m=64,a=1860,s=891}
{x=743,m=203,a=1216,s=586}
{x=562,m=2230,a=428,s=1056}
{x=907,m=2499,a=2323,s=35}
{x=895,m=64,a=521,s=1616}
{x=2335,m=1661,a=705,s=1811}
{x=3875,m=2100,a=726,s=82}
{x=478,m=3106,a=1652,s=145}
{x=394,m=1255,a=391,s=256}
{x=1074,m=306,a=110,s=560}
{x=1099,m=1158,a=2338,s=1562}
{x=1030,m=2433,a=783,s=3066}
{x=2587,m=17,a=739,s=2788}
{x=1876,m=1459,a=145,s=3440}
{x=97,m=230,a=722,s=622}
{x=2634,m=222,a=1941,s=3208}
{x=1410,m=1860,a=1561,s=27}
{x=104,m=1735,a=947,s=146}
{x=323,m=576,a=139,s=1924}
{x=381,m=20,a=1266,s=2119}
{x=287,m=154,a=524,s=69}
{x=718,m=2618,a=138,s=373}
{x=864,m=416,a=1637,s=3088}
{x=848,m=1992,a=400,s=2460}
{x=1486,m=180,a=1061,s=144}
{x=1435,m=2279,a=1417,s=2800}
{x=438,m=289,a=384,s=231}
{x=853,m=157,a=2367,s=608}
{x=1214,m=631,a=195,s=620}
{x=238,m=501,a=241,s=275}
{x=458,m=255,a=1644,s=2634}
{x=2638,m=508,a=947,s=1523}
{x=1069,m=1215,a=248,s=556}
{x=746,m=1738,a=2812,s=1901}
{x=231,m=721,a=179,s=179}
{x=103,m=234,a=808,s=1723}
{x=1818,m=2372,a=64,s=10}
{x=784,m=1447,a=483,s=188}
{x=1495,m=244,a=1788,s=1054}
{x=152,m=618,a=908,s=324}
{x=3083,m=1473,a=645,s=1293}
{x=64,m=1650,a=171,s=1497}
{x=1708,m=1167,a=1002,s=628}
{x=808,m=1930,a=1475,s=2057}
{x=1690,m=89,a=1585,s=460}
{x=2422,m=1317,a=246,s=2592}
{x=526,m=250,a=410,s=709}
{x=273,m=222,a=117,s=989}

243
day-19/src/bin/part1.rs Normal file
View File

@ -0,0 +1,243 @@
use std::collections::HashMap;
use nom::{
branch::alt,
character::complete::{self, alpha1, line_ending, one_of},
combinator::{map, value},
multi::{count, separated_list1},
sequence::{delimited, pair, separated_pair, tuple},
IResult,
};
fn main() {
println!("{}", part1(include_str!("./input.txt")));
}
fn part1(input: &str) -> u32 {
let (workflows, parts) = input_parser(input).expect("invalid input").1;
let starting_workflow = workflows.get("in").expect("no starting workflow");
parts
.into_iter()
.filter(|p| {
let mut current_workflow = starting_workflow;
let mut current_rule = 0;
loop {
let rule = current_workflow.rules.get(current_rule);
if let Some(rule) = rule {
let part_value = p.get(rule.category);
let condition = rule.condition;
if (condition == Condition::GreaterThan && part_value > rule.value)
|| (condition == Condition::LessThan && part_value < rule.value)
{
if rule.target == "A" {
return true;
}
if rule.target == "R" {
return false;
}
current_workflow =
workflows.get(rule.target).expect("invalid target workflow");
current_rule = 0;
} else {
current_rule += 1;
}
} else {
if current_workflow.finally == "A" {
return true;
}
if current_workflow.finally == "R" {
return false;
}
current_workflow = workflows
.get(current_workflow.finally)
.expect("invalid finally workflow");
current_rule = 0;
}
}
})
.map(|p| p.x + p.m + p.a + p.s)
.sum()
}
type WorflowsAndParts<'a> = (HashMap<&'a str, Workflow<'a, 'a>>, Vec<Part>);
fn input_parser(i: &str) -> IResult<&str, WorflowsAndParts> {
separated_pair(
map(
separated_list1(line_ending, workflow_parser),
HashMap::from_iter,
),
count(line_ending, 2),
separated_list1(line_ending, part_parser),
)(i)
}
fn workflow_parser(i: &str) -> IResult<&str, (&str, Workflow)> {
map(
pair(
alpha1,
delimited(
complete::char('{'),
separated_pair(
separated_list1(complete::char(','), rule_parser),
complete::char(','),
alpha1,
),
complete::char('}'),
),
),
|(label, (rules, finally))| (label, Workflow { rules, finally }),
)(i)
}
fn rule_parser(i: &str) -> IResult<&str, Rule> {
map(
tuple((
category_parser,
alt((
value(Condition::GreaterThan, complete::char('>')),
value(Condition::LessThan, complete::char('<')),
)),
complete::u32,
complete::char(':'),
alpha1,
)),
|(category, condition, value, _, target)| Rule {
category,
condition,
value,
target,
},
)(i)
}
fn category_parser(i: &str) -> IResult<&str, Category> {
map(one_of("xmas"), |c| {
Category::try_from(c).expect("invalid category")
})(i)
}
fn part_parser(i: &str) -> IResult<&str, Part> {
map(
delimited(
complete::char::<&str, nom::error::Error<&str>>('{'),
separated_list1(
complete::char(','),
separated_pair(category_parser, complete::char('='), complete::u32),
),
complete::char('}'),
),
|v| {
Part::new(
v.iter()
.find(|(c, _)| c == &Category::ExtremelyCoolLooking)
.unwrap()
.1,
v.iter().find(|(c, _)| c == &Category::Musical).unwrap().1,
v.iter()
.find(|(c, _)| c == &Category::Aerodynamic)
.unwrap()
.1,
v.iter().find(|(c, _)| c == &Category::Shiny).unwrap().1,
)
},
)(i)
}
#[derive(Debug, Clone, Copy, PartialEq, Eq, Hash)]
enum Category {
ExtremelyCoolLooking,
Musical,
Aerodynamic,
Shiny,
}
impl TryFrom<char> for Category {
type Error = ();
fn try_from(value: char) -> Result<Self, Self::Error> {
match value {
'x' => Ok(Self::ExtremelyCoolLooking),
'm' => Ok(Self::Musical),
'a' => Ok(Self::Aerodynamic),
's' => Ok(Self::Shiny),
_ => Err(()),
}
}
}
#[derive(Debug, Clone, Copy, PartialEq, Eq, Hash)]
struct Part {
x: u32,
m: u32,
a: u32,
s: u32,
}
impl Part {
pub fn new(x: u32, m: u32, a: u32, s: u32) -> Self {
Self { x, m, a, s }
}
pub fn get(&self, category: Category) -> u32 {
match category {
Category::ExtremelyCoolLooking => self.x,
Category::Musical => self.m,
Category::Aerodynamic => self.a,
Category::Shiny => self.s,
}
}
}
#[derive(Debug, Clone, PartialEq, Eq, Hash)]
struct Workflow<'a, 'b> {
rules: Vec<Rule<'b>>,
finally: &'a str,
}
#[derive(Debug, Clone, Copy, PartialEq, Eq, Hash)]
struct Rule<'a> {
category: Category,
condition: Condition,
value: u32,
target: &'a str,
}
#[derive(Debug, Clone, Copy, PartialEq, Eq, Hash)]
enum Condition {
GreaterThan,
LessThan,
}
#[cfg(test)]
mod tests {
use super::*;
use indoc::indoc;
#[test]
fn test_part1() {
assert_eq!(
part1(indoc!(
"
px{a<2006:qkq,m>2090:A,rfg}
pv{a>1716:R,A}
lnx{m>1548:A,A}
rfg{s<537:gd,x>2440:R,A}
qs{s>3448:A,lnx}
qkq{x<1416:A,crn}
crn{x>2662:A,R}
in{s<1351:px,qqz}
qqz{s>2770:qs,m<1801:hdj,R}
gd{a>3333:R,R}
hdj{m>838:A,pv}
{x=787,m=2655,a=1222,s=2876}
{x=1679,m=44,a=2067,s=496}
{x=2036,m=264,a=79,s=2244}
{x=2461,m=1339,a=466,s=291}
{x=2127,m=1623,a=2188,s=1013}
"
)),
19114
);
}
}

263
day-19/src/bin/part2.rs Normal file
View File

@ -0,0 +1,263 @@
use std::collections::{hash_map::RandomState, HashMap};
use nom::{
branch::alt,
character::complete::{self, alpha1, line_ending, one_of},
combinator::{map, value},
multi::separated_list1,
sequence::{delimited, pair, separated_pair, tuple},
IResult,
};
fn main() {
println!("{}", part2(include_str!("./input.txt")));
}
fn part2(input: &str) -> u64 {
let workflows: HashMap<&str, Workflow<'_, '_>, RandomState> = map(
separated_list1(line_ending, workflow_parser),
HashMap::from_iter,
)(input)
.expect("invalid input")
.1;
let starting_workflow = workflows.get("in").expect("no starting workflow");
let mut stack = vec![(starting_workflow, Part::new())];
let mut possibilities = 0;
while let Some((workflow, part)) = stack.pop() {
let mut pass_on_part = part;
for rule in &workflow.rules {
let mut local_part = pass_on_part;
let (split_a, split_b) = pass_on_part
.get(rule.category)
.split(rule.value, rule.condition);
pass_on_part.set(rule.category, split_a);
local_part.set(rule.category, split_b);
if !local_part.get(rule.category).is_empty() {
match rule.target {
"A" => {
possibilities += local_part.combination_count();
continue;
}
"R" => {}
target => {
stack.push((workflows.get(target).expect("invalid target"), local_part))
}
}
}
if local_part.get(rule.category).is_empty() {
continue;
}
}
match workflow.finally {
"R" => continue,
"A" => possibilities += pass_on_part.combination_count(),
target => stack.push((
workflows.get(target).expect("invalid finally"),
pass_on_part,
)),
}
}
possibilities
}
fn workflow_parser(i: &str) -> IResult<&str, (&str, Workflow)> {
map(
pair(
alpha1,
delimited(
complete::char('{'),
separated_pair(
separated_list1(complete::char(','), rule_parser),
complete::char(','),
alpha1,
),
complete::char('}'),
),
),
|(label, (rules, finally))| (label, Workflow { rules, finally }),
)(i)
}
fn rule_parser(i: &str) -> IResult<&str, Rule> {
map(
tuple((
category_parser,
alt((
value(Condition::GreaterThan, complete::char('>')),
value(Condition::LessThan, complete::char('<')),
)),
complete::u16,
complete::char(':'),
alpha1,
)),
|(category, condition, value, _, target)| Rule {
category,
condition,
value,
target,
},
)(i)
}
fn category_parser(i: &str) -> IResult<&str, Category> {
map(one_of("xmas"), |c| {
Category::try_from(c).expect("invalid category")
})(i)
}
#[derive(Debug, Clone, Copy, PartialEq, Eq, Hash)]
enum Category {
ExtremelyCoolLooking,
Musical,
Aerodynamic,
Shiny,
}
impl TryFrom<char> for Category {
type Error = ();
fn try_from(value: char) -> Result<Self, Self::Error> {
match value {
'x' => Ok(Self::ExtremelyCoolLooking),
'm' => Ok(Self::Musical),
'a' => Ok(Self::Aerodynamic),
's' => Ok(Self::Shiny),
_ => Err(()),
}
}
}
#[derive(Debug, Clone, Copy, PartialEq, Eq, Hash)]
struct ValueRange {
min: u16,
max: u16,
}
impl ValueRange {
fn new(min: u16, max: u16) -> Self {
Self { min, max }
}
fn combination_count(&self) -> u64 {
(self.max + 1 - self.min) as u64
}
fn split(&self, threshold: u16, cond: Condition) -> (ValueRange, ValueRange) {
match cond {
Condition::GreaterThan => (
ValueRange::new(self.min, threshold),
ValueRange::new(threshold + 1, self.max),
),
Condition::LessThan => (
ValueRange::new(threshold, self.max),
ValueRange::new(self.min, threshold - 1),
),
}
}
pub fn is_empty(&self) -> bool {
self.min > self.max
}
}
#[derive(Debug, Clone, Copy, PartialEq, Eq, Hash)]
struct Part {
x: ValueRange,
m: ValueRange,
a: ValueRange,
s: ValueRange,
}
impl Part {
pub fn new() -> Self {
Self {
x: ValueRange::new(1, 4000),
m: ValueRange::new(1, 4000),
a: ValueRange::new(1, 4000),
s: ValueRange::new(1, 4000),
}
}
pub fn get(&self, category: Category) -> ValueRange {
match category {
Category::ExtremelyCoolLooking => self.x,
Category::Musical => self.m,
Category::Aerodynamic => self.a,
Category::Shiny => self.s,
}
}
pub fn set(&mut self, category: Category, range: ValueRange) {
match category {
Category::ExtremelyCoolLooking => self.x = range,
Category::Musical => self.m = range,
Category::Aerodynamic => self.a = range,
Category::Shiny => self.s = range,
}
}
pub fn combination_count(&self) -> u64 {
self.s.combination_count()
* self.a.combination_count()
* self.m.combination_count()
* self.x.combination_count()
}
}
#[derive(Debug, Clone, PartialEq, Eq, Hash)]
struct Workflow<'a, 'b> {
rules: Vec<Rule<'b>>,
finally: &'a str,
}
#[derive(Debug, Clone, Copy, PartialEq, Eq, Hash)]
struct Rule<'a> {
category: Category,
condition: Condition,
value: u16,
target: &'a str,
}
#[derive(Debug, Clone, Copy, PartialEq, Eq, Hash)]
enum Condition {
GreaterThan,
LessThan,
}
#[cfg(test)]
mod tests {
use super::*;
use indoc::indoc;
#[test]
fn test_part2() {
assert_eq!(
part2(indoc!(
"
px{a<2006:qkq,m>2090:A,rfg}
pv{a>1716:R,A}
lnx{m>1548:A,A}
rfg{s<537:gd,x>2440:R,A}
qs{s>3448:A,lnx}
qkq{x<1416:A,crn}
crn{x>2662:A,R}
in{s<1351:px,qqz}
qqz{s>2770:qs,m<1801:hdj,R}
gd{a>3333:R,R}
hdj{m>838:A,pv}
{x=787,m=2655,a=1222,s=2876}
{x=1679,m=44,a=2067,s=496}
{x=2036,m=264,a=79,s=2244}
{x=2461,m=1339,a=466,s=291}
{x=2127,m=1623,a=2188,s=1013}
"
)),
167409079868000
);
}
}