Compare commits
	
		
			5 Commits
		
	
	
		
			8559be1491
			...
			786a5bae35
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 786a5bae35 | |||
| 8e451050b1 | |||
| 761013df81 | |||
| eb9e770a94 | |||
| 13888edaff | 
@ -1,13 +0,0 @@
 | 
				
			|||||||
2413432311323
 | 
					 | 
				
			||||||
3215453535623
 | 
					 | 
				
			||||||
3255245654254
 | 
					 | 
				
			||||||
3446585845452
 | 
					 | 
				
			||||||
4546657867536
 | 
					 | 
				
			||||||
1438598798454
 | 
					 | 
				
			||||||
4457876987766
 | 
					 | 
				
			||||||
3637877979653
 | 
					 | 
				
			||||||
4654967986887
 | 
					 | 
				
			||||||
4564679986453
 | 
					 | 
				
			||||||
1224686865563
 | 
					 | 
				
			||||||
2546548887735
 | 
					 | 
				
			||||||
4322674655533
 | 
					 | 
				
			||||||
							
								
								
									
										141
									
								
								day17/input.txt
									
									
									
									
									
								
							
							
						
						
									
										141
									
								
								day17/input.txt
									
									
									
									
									
								
							@ -1,141 +0,0 @@
 | 
				
			|||||||
222343122415245553243251316124223234134666332224124211645376775672443247264263475261513546522316162532215534453661231232515522214351143451211
 | 
					 | 
				
			||||||
422125443253354142511545636246664666565355152246453231651172747635424163415626462753445445312334225221624336126244661514234445544425223533122
 | 
					 | 
				
			||||||
131212112421423414125516356342555542626661163526211536677376523712262371162153644117776261645533664544366146314432523222515425314231311544521
 | 
					 | 
				
			||||||
131334344235153415214541223454455223563154114267331524774136127715554416125273543276346471735741663351266324144422511534542234341513351345352
 | 
					 | 
				
			||||||
314541545523112111131565114333211153312641614321771374726154434476767125613311254537363422511721275135434164664442151263234241114111121141334
 | 
					 | 
				
			||||||
435153335153513534132112326653656626231351436457153446433363235565156156723233715473535244413451723176561153261562445512312413413513135513241
 | 
					 | 
				
			||||||
235243535523134543445216214455445352435554624255171271225755313626173154112144673146273747537614771377613244145436355342536323123434425211113
 | 
					 | 
				
			||||||
132552152551514515631323412533333446136243376366556365574745474652757277632216317677316551253673465513776336664225626313216456312542531241352
 | 
					 | 
				
			||||||
311415311541314143614162642634556464574541744355655753776632763662153656721435137347422375344242225276244673434333351454464536453212424421425
 | 
					 | 
				
			||||||
453351344131342126143165264626543453632747531417235617257564537542611276314542732241535726557435722271523761452243145343543365433423153132344
 | 
					 | 
				
			||||||
424354321333252642533513531241416236636427325176724425161362563217173773414665312244155777552374513335344162564462411154332652126231133233331
 | 
					 | 
				
			||||||
433224533551436134314641523151361154615353522622137441214134673454347752343853221756746664765556521762762464233333523123643145626644231443435
 | 
					 | 
				
			||||||
243311313556533564523443331214721572253144611715156456321767676655457736255732864573164467712433421256325731135656541255561161224441152415141
 | 
					 | 
				
			||||||
511211214252345356344156642436611545463224342452742717585325436325574336455336582448256836717741726221177352616311422112513255165441212221131
 | 
					 | 
				
			||||||
244253443163544142511413446172632624762126756145146775348573476557644782564438437852836725866452746165474553473737534665123425113435563332453
 | 
					 | 
				
			||||||
232155346345514313654314235557517112176174776332136456448427547478426265844263882743533766568854547675464477171376662424251312612162632514355
 | 
					 | 
				
			||||||
424114441642564135264345176163444365144163124128832285838626688224834432458556377773645427653638562736676174576737574642156232566466636441124
 | 
					 | 
				
			||||||
543244331213246512421551417132132647763461226245235583478358556478588445828784366325778587856624776125647332126411416416253326543252561355453
 | 
					 | 
				
			||||||
513411632124243263566153173255453461117356682265475822242236525286334354628536868726586284535383867467645552277715213631624352612331534144225
 | 
					 | 
				
			||||||
234513324414264131211345613416736552211115685767773523645885727834464346536233245827443237753783724626566246761647646475456131431415434413214
 | 
					 | 
				
			||||||
132312323255146664114745115275443572754326543474673247542856435836784453584863735676475556838547655484787272216413226712176641452341133361621
 | 
					 | 
				
			||||||
324445311115236332563161165371142354332783687877726543524347444677384655338335874866474624655543543466338566764524432633543363631622335214314
 | 
					 | 
				
			||||||
452146561262254136627644671525514257523265444635773245326674352228844844533536247443486645863647324742823822411266212747246263222143515531123
 | 
					 | 
				
			||||||
323443456261326564347757145611113632534754323645837762327643383533554795688333775647234446628482555868382485343642524356327477353226234131236
 | 
					 | 
				
			||||||
323566623463524644662155345214734554448367587534458465333783778836737748873896436675564776876254472473382773351746477537426351164321556552155
 | 
					 | 
				
			||||||
411624314463555226413151162214157826642348553426375774773937688356445778864665387877397647688288645648488526683635462551221145364643422311353
 | 
					 | 
				
			||||||
632541423444624336526576464457777686224586376437338832948677343497666833369685846994446858346385546773453274862246234173462724342631561154224
 | 
					 | 
				
			||||||
353552612514333121215745416727247272652423544685753368594647394695658845883548858535734584333432476287445274435882257755366724515216151451335
 | 
					 | 
				
			||||||
532166314441574113623175262414284358754786632434337878589943898388748395969493754638344944356356855723827482463322173565111471477266643531656
 | 
					 | 
				
			||||||
116644351623354144151425116542234543365536844644456554366885339853375594997998864974865377578863643354482658652565456654732562467462642222633
 | 
					 | 
				
			||||||
425265565534525427323521564886284475834357765873953575557676864375449896735695696945686539933897587748627756658646775714547636543542445454453
 | 
					 | 
				
			||||||
535223341313647443711526456446656284686644344893747447894898636684595668686646634379736944587367734766868686525582828566224141647377452234555
 | 
					 | 
				
			||||||
363661154543263115262561162483434662346246798873478436638737549697754638834495375733735333645433574877375276735684662372751455123234415466135
 | 
					 | 
				
			||||||
233425541263155564422777566657463284532222644739657858356574964435535676435594635788954898867344838753677578547362236357265747553176223645334
 | 
					 | 
				
			||||||
516113313346251471245336736766463235445577574763999559496983357388779634999695985559489635746544658453383775634426265623615715313624324613363
 | 
					 | 
				
			||||||
325162436525537742416463226466422582452664444569687695737766869564846698477563438574369658749388443473974527623665566388541124766765465414216
 | 
					 | 
				
			||||||
246532424466452274271137247462733834328375758733755764656833968984956876697799766884997394499744585594587876625677723447244217267426213343664
 | 
					 | 
				
			||||||
164356325132241765153442235356485242287535595375398869579646888545895757975449659944533834737579865398575662388572336243423321763313272155166
 | 
					 | 
				
			||||||
563615555622724634724833866443433524894838958833799835363644977657658578544664475868679458747866349983337933858733558557637772576116524351364
 | 
					 | 
				
			||||||
415635136113175137578553536586564768643559866697595733497557879468449998976698759797676436636689587877974934738258785642847435574452213713115
 | 
					 | 
				
			||||||
611145153512463742256332755487858466583796497738685664885658748948569545664445888744947857868589779795933867483673776857358564657524755764663
 | 
					 | 
				
			||||||
235565633417713142257732254688636564985938796475899556649457697557496557466787887559566976984578789695478656638728764846466352277661663613361
 | 
					 | 
				
			||||||
621414363456434251274757622526573747939964946885796964745598945469487687577499977988878866574434454755956575894225366755752223145132155653231
 | 
					 | 
				
			||||||
345131227736331632753528624737877993467633874573544566489488585879587798745544677645759486797999989373758553748378762622865225676664655255241
 | 
					 | 
				
			||||||
211147374365347566347683538644229836375367399779966469889799674657475784657559849567645885568589949973844765649576234674566626355732735375222
 | 
					 | 
				
			||||||
123377577423217135757464227844458664877347575684876765589445958984848645558957589999985649678755757487567997496322362828232445742466637677526
 | 
					 | 
				
			||||||
664165716524474573468574845478963396633746335989586478477469677874488696466969855457589699479795777786993453995866655558838835473455711456363
 | 
					 | 
				
			||||||
645354217411347423778226725287476938984748595969986859957845897656645797969945967774756979786597495489759753559534884668577746471267563715146
 | 
					 | 
				
			||||||
641123731653617153523878786635997676839634584755798896844786989789997886975976877949768456676679545757849946967975863276534664727276625714772
 | 
					 | 
				
			||||||
115172313432542554343534322666684547383747359496846665858866986576677885977798965677465955688547658777937483437698822255673227856674321437423
 | 
					 | 
				
			||||||
412316124234335666538374784464654983653484498444688865778477997658875656978599866558669858496479969969883747883595375635748886535531163731666
 | 
					 | 
				
			||||||
126215534552633672772444476653659865338587448788645985679486758768567978966789759768556688875958549895757653789978826784367383554244325537527
 | 
					 | 
				
			||||||
252471722164728674273366346869733763887789597776444684764998985757556667899857586887855996664484555498483585754587755247628423684671244526734
 | 
					 | 
				
			||||||
616643241174113524686752733973994433637977478579974486858559967566675596878985789668957757945476696698659695977366876442282382768473657366141
 | 
					 | 
				
			||||||
433715625621658365787576378559966694694594565764577974766866977599956779776859687775695787565694987685963787977966448785772368444344613132341
 | 
					 | 
				
			||||||
542654365337336826434765643879738646353964647955974749776876686976656857777555965796959755779797949695874357763646457888473355582731254116326
 | 
					 | 
				
			||||||
461216754736354442526774233456439439344649448885449769679668978899596596779679669865776767595846454969558697477357393642534444663773547743151
 | 
					 | 
				
			||||||
242515737157657333842228548349875463457585648494866999577597668698587656558567788999587689857767876885764484449548964773473277753231345166735
 | 
					 | 
				
			||||||
654521345226446835568566235799768737539786475876888887965595966585598966967969975867759665599758868667576445864433979732538253832712175534524
 | 
					 | 
				
			||||||
115512724255847238822523769738898864344596868468594857859588665686578579798878998656799555798598889485694534558457599364226342568753677472213
 | 
					 | 
				
			||||||
111524524557584843753648338688446565566879945758747566968678858898688798787995576956865896565768766698768659698554344826255288878683415552615
 | 
					 | 
				
			||||||
775523534424885336584535598468769386864885649976596679699998877966986778776767559667869889767766556949956568378399476985828735885425764761532
 | 
					 | 
				
			||||||
617234235723887272453554398456849533986998847969886896697596899979688786876777696866697569685659688446949473894494359678374775655237573674227
 | 
					 | 
				
			||||||
731315731775542663287374348536374735499748575465485866966768699899697997797776666566989778755777686999847946948853933693544267753841326646546
 | 
					 | 
				
			||||||
722426246522232587267567746363433367778759685487558796666966958776698867986668698666876866775886659846776955633755765593638285378256357434712
 | 
					 | 
				
			||||||
174725351666826552875547497865663863549888789874668876958895676696978768897788786788566955869997548858768874638777786742243328886625132571731
 | 
					 | 
				
			||||||
611354237262464432722652894576534365759676599966965877965957687768769888968769696957679665987557457444944459839769348686383583662783465636276
 | 
					 | 
				
			||||||
435775645554577458385385799454458446877466964957585556758766679978876698869886969697899756896864788684659949467367797467452464686586746747527
 | 
					 | 
				
			||||||
326715157438852348356648795697795987947557758498877979757678677886679987996677668886868888557795864545877549896579885386328386465786533157726
 | 
					 | 
				
			||||||
453273273424255488663856445483976736667859995777897779896656697978997888787987898778776958957796758748894869487957534497554376546868722122324
 | 
					 | 
				
			||||||
224573216435873475783673336556553645879964994546857977556976898696968678989979687688777875655579994576659674597887987885384834758677414425113
 | 
					 | 
				
			||||||
356241135726344637684746374354974769468887978766569659956588999669799779786678667886579699675678884889486587434679643859352582448655434457222
 | 
					 | 
				
			||||||
466565323122567376356874397989745956794895966548765989989778688799697678896789997978696969665976575677558444868875986457762338452225134143337
 | 
					 | 
				
			||||||
362264215456463347238855743779549969969487765646768855768895876877976886666866799968989767688568764586578687569679978449782326532643416155546
 | 
					 | 
				
			||||||
671362724447463788282378857469553747694544454845755975585656699878677799678797776968799697957896898878765444867363549353272748888443452166364
 | 
					 | 
				
			||||||
632542654733754847425787585687488755596748847964799999775985798869786789699666867675565568797969676665954954838875438688564548862244145146171
 | 
					 | 
				
			||||||
333723417316447367476286584684499973896998895898557855668598997699996977697796768788767776689759949696664864687338847464274357245662617625121
 | 
					 | 
				
			||||||
732722335132788573566373398994377893654688989578766978658865988697879899789898877758688978567997675756877983739477395738266566365866553224517
 | 
					 | 
				
			||||||
147177514747474242267782783587784747967985778647866665897959877679967669667689876857669669767556998597597497483549887695587764775634662343617
 | 
					 | 
				
			||||||
152744472376652374322667687839455953897495766449899756875956679668789688868676978978876787578985556849965685833354883453248267842384616432657
 | 
					 | 
				
			||||||
217227543612352346346455856939488455758985798868598588765697888677977868879697796686766696678556576857569777547694747435272652536672167123712
 | 
					 | 
				
			||||||
744625215616674868776537785459394998859647888485449778786556769796876987889777989756758976977758496584958578978633843394583557326773745211217
 | 
					 | 
				
			||||||
353354332722486863626455784779737558677796677557648786868756998567779997999757769989968679778794444858495938377534839655447657354377534537617
 | 
					 | 
				
			||||||
351162251452745473452566496983484689397949849568679798775655588857855767769795678968695766898846549555848585493436735966444566758545364773274
 | 
					 | 
				
			||||||
546334341147183722785558798496869978864895677895756565879578585766957665575757696669676677769768545948765446463585354842584745473612425647573
 | 
					 | 
				
			||||||
235615763364478535767825263879546994497978874484569465769576969857869669765659777668868977865946966479776587987999955433355672374557554754214
 | 
					 | 
				
			||||||
162177325222163583735436483646438894396659587698644456886655596959879587966867768858997789444759867989565846639353845278562446263633245724416
 | 
					 | 
				
			||||||
324535255452483383635664425784958857579867676497445879975595969977679879855779697798889657664476857564676937793853344868547244368834643131142
 | 
					 | 
				
			||||||
121347276513238722442368557665693779499584456766988769868757758795788956896585869778678687556788794995887699638544336543625582864246234111541
 | 
					 | 
				
			||||||
357771157266317334828437783465549356369747964978875778866775965679685977988796799568586768676664767564576835757749675276226376757244531177246
 | 
					 | 
				
			||||||
336664616327762746632336856333359783983467896468668468658857596888666655696975568657694759566847599666396674475446532283582787232143364371132
 | 
					 | 
				
			||||||
644533212754142233635788744897443835653636699755644785889878558985567878858696858779788657475547995487649399794638387758824355331366214575725
 | 
					 | 
				
			||||||
222217676717612667687783367437478679946969645869469768494864887557985785659965856994457654994548995554598868743539788752855264561637271324324
 | 
					 | 
				
			||||||
356452154463414577848785374339498366535638544946846765677495769785557579699659788879447959897745467466459849543743454246822537753427335371562
 | 
					 | 
				
			||||||
343351256333451586862433643627656985753774749546555768998795848687576559887698545798748988498774696693748665338953758884323743215516455337651
 | 
					 | 
				
			||||||
511156433162323673647444877388393898578477588665844949845684789786485757669794987664595874795599974455755347864958728824643583546532455523751
 | 
					 | 
				
			||||||
156124537652656126446766564883685565845949468648655489495444579455874554846945778967786444756587898964737436487344256846452377111452125151424
 | 
					 | 
				
			||||||
515264356113762652852852632686537484556764597765774578755556886965448899978985694964457598494775673883444869546887836668355228143455736361562
 | 
					 | 
				
			||||||
263512646525146141226625365446528679473694599878945468469659775468694555669548954648468546665655847884688365888823562232347546127534712221733
 | 
					 | 
				
			||||||
631415241711525626678448673422265459959576695493999586674865475767744965494946497644686744965594334353963643655244478563353652375272512755651
 | 
					 | 
				
			||||||
233341711151632262167275682837682337594668593834657957999678754665457846558698875995554875885564465558544593484682334467458266753354353656363
 | 
					 | 
				
			||||||
222614621174264456548568855775763264556684446457483755666594465554896878549965797747587445795345639937745754468637877328233727712145444373316
 | 
					 | 
				
			||||||
551136576466563613374865837744634548656596546959875864946578986489646467467887584454698786369755639588797883757583882864432762672266561742114
 | 
					 | 
				
			||||||
311433545766254471655428367633528758869667674337353886355568568977559794557448545869856978986385835684993879575657778365536445625371464633155
 | 
					 | 
				
			||||||
223612464456771261577683747465843843667648368983574634838577897765496687876598844667977633334687854753563787465237347324763236171472235426346
 | 
					 | 
				
			||||||
411245121677351625555347323585443444334598696449339998397379788744556985684748696646376458494657966586849537253887746577841254462522431254352
 | 
					 | 
				
			||||||
344346233632636772414765673728476885836598589955558748979779588656646877576889768598337348786569379345443684386546372358847445714773517622512
 | 
					 | 
				
			||||||
155323536362462251246768675874228887274856495665585569666835536867574987794867838438565638693854398377677783434776265675564455312663443423541
 | 
					 | 
				
			||||||
331566446775752674417132753235465665833378447847639386878845593445734945386694688999635777683567968539426228468486664337643254264256612362121
 | 
					 | 
				
			||||||
243564654224225645722672382353864676463257496747548887493585987546678658735985743376384577953533946647357564447863573451724364472125432653566
 | 
					 | 
				
			||||||
342315614225414552353574355435638346877654437484463854837898965395385547754648364866393337683989446882326338262227448314144441743477561422165
 | 
					 | 
				
			||||||
513316635431624236671443348277886572254832458877847668477593794644585888563857755634797589885668862754772785358487877315135613177367144545513
 | 
					 | 
				
			||||||
463143244643262172563515774358878556748352525757567987986693359853994963575439443448643467386743366524235883462535432614464455735443452664134
 | 
					 | 
				
			||||||
365641135114444646623465131227245648484522527682468766639838853356859443957586854538395483886846572325432336737857272623363152162131551135414
 | 
					 | 
				
			||||||
416313341334271754356764361744638674522648825426627539586358437534848469663986377869797354638474474353788632454247175546246417444136416435644
 | 
					 | 
				
			||||||
224353155431264253763746646441542886447853826453463553364576374757797585985553484899859547773742768633328427884282476754133441524461616242643
 | 
					 | 
				
			||||||
141663652631255115673535171111246265842334873322667887864398959494389595436394448689564435578232373254536888873517235136312276614212451451513
 | 
					 | 
				
			||||||
124131511566566612435515461237554545678463532355284383577958338477334574565899548354995646534573786226335788675417311262514713363312364535154
 | 
					 | 
				
			||||||
423124641651141434731445642547213258886735546328578275442562699767675575457466479427885838355373878586875834224154546773247146645646322335264
 | 
					 | 
				
			||||||
412644326632526437735316412561445417468882886666655743427476665574794946797787288666754744722668682487625266217525212752446411411125122652443
 | 
					 | 
				
			||||||
533453646465125514654252753512273714342227373732733663723654553522224855828427587263828376724486786422622551345652174733731235533661345526462
 | 
					 | 
				
			||||||
431416626556561415256423726364711356216462533453778624228776264745488556248346558664685886255267664468734267241413666377354236365315112133322
 | 
					 | 
				
			||||||
115242144546551242654657115464153653733572255453735867582743877872748475375858445224247557346684865447435434415136572343667245436453541641214
 | 
					 | 
				
			||||||
211445545143351463615353774344215444543156828652686467572385233427763332873666832447256386848435536242337137777716372765516254142315334335233
 | 
					 | 
				
			||||||
345124663224645321264314114673647256557756426376735374628552375257437773764536467386624358238642865332573246663566211211655655563524242452555
 | 
					 | 
				
			||||||
314351264524343426135362454521352527263736457447533445374485277766767738682474542365754582457568722614424111744153725635141565436222616112315
 | 
					 | 
				
			||||||
525142531331665442641251651451342365334554162254374267466577736465886625773232626738363773743786773241666727445735231415436342625513255235151
 | 
					 | 
				
			||||||
543245142256442454155334231734217734761146755176638778856523266374354672783363252424683478557527343237227211135754547531342136551132351221533
 | 
					 | 
				
			||||||
241355115114515145351235241342577311663523713245571552423844478483444456674576776374774635321762611146175633416417526461446534624524525232351
 | 
					 | 
				
			||||||
413212231435125464562416642131514721163172662635774761555772466528432746222877628357558463622434577676277711461224526611415645224221334321153
 | 
					 | 
				
			||||||
424114552242412235261232556412366663124614547557116436567672766285253724382874567666431356536715216512355113511563132462412461555112225422135
 | 
					 | 
				
			||||||
322324544333135432235125224253374616723165212337472223432464246434784434268261665524555163346167575177573432151165141342526636661664333152245
 | 
					 | 
				
			||||||
533322454514225135644666511564116113743567665217446774461763723457213436114546254524754413534661176555531123216654634336153535555615455221351
 | 
					 | 
				
			||||||
345114245113253556125335351622625171466165175642167753751336711273734343723253343654164414153211641676412352766561245653215262351455523141451
 | 
					 | 
				
			||||||
142421541514212154334545211465656444644552463442357616615277117635256363621723512341776351424463622726131565431516465664346151153212233245553
 | 
					 | 
				
			||||||
444314343434312135211364665242441535527647475416223551347736416724264751235567161762631557147415445546211321423221136662344161541525343455425
 | 
					 | 
				
			||||||
513343214231252255165411335621632642146147645756642561211667322537371252122672641421372561555336143123644446534414131135624333443543522413531
 | 
					 | 
				
			||||||
151133414553422411155141354122545416221132657162133367556711163132611352466177573117122527412137673543111622364234433423115531533515415532534
 | 
					 | 
				
			||||||
344341433553215433332561124312211661162315615567541645475225431414323527474442612165214546553775576346352241352363416414626442233143123431324
 | 
					 | 
				
			||||||
312334123334252355135521123323245125516132154636463653576675247514555746177477533534522123547665145656414436131454466514531422525141331441324
 | 
					 | 
				
			||||||
221234522113214232242154165523542235561622643243233434644217742623556626525264626677654256257462621433131425222466152534235213545112335523443
 | 
					 | 
				
			||||||
							
								
								
									
										214
									
								
								day17/main.go
									
									
									
									
									
								
							
							
						
						
									
										214
									
								
								day17/main.go
									
									
									
									
									
								
							@ -1,214 +0,0 @@
 | 
				
			|||||||
package main
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import (
 | 
					 | 
				
			||||||
	"bufio"
 | 
					 | 
				
			||||||
	_ "embed"
 | 
					 | 
				
			||||||
	"fmt"
 | 
					 | 
				
			||||||
	"sort"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	aoc "go.sour.is/advent-of-code"
 | 
					 | 
				
			||||||
)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
// var log = aoc.Log
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
func main() { aoc.MustResult(aoc.Runner(run)) }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
type result struct {
 | 
					 | 
				
			||||||
	valuePT1 int
 | 
					 | 
				
			||||||
	valuePT2 int
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
func (r result) String() string { return fmt.Sprintf("%#v", r) }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
func run(scan *bufio.Scanner) (*result, error) {
 | 
					 | 
				
			||||||
	var m Map
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	for scan.Scan() {
 | 
					 | 
				
			||||||
		text := scan.Text()
 | 
					 | 
				
			||||||
		m = append(m, []rune(text))
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	result := result{}
 | 
					 | 
				
			||||||
	// result.valuePT1 = search(m, 1, 3)
 | 
					 | 
				
			||||||
	result.valuePT2 = search(m, 4, 10)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	return &result, nil
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
var (
 | 
					 | 
				
			||||||
	ZERO = point{0, 0}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	UP = point{-1, 0}
 | 
					 | 
				
			||||||
	DN = point{1, 0}
 | 
					 | 
				
			||||||
	LF = point{0, -1}
 | 
					 | 
				
			||||||
	RT = point{0, 1}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	INF = int(^uint(0) >> 1)
 | 
					 | 
				
			||||||
)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
type Map [][]rune
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
func (m *Map) Get(p point) (point, int, bool) {
 | 
					 | 
				
			||||||
	if !m.Valid(p) {
 | 
					 | 
				
			||||||
		return [2]int{0, 0}, 0, false
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	return p, int((*m)[p[0]][p[1]] - '0'), true
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
func (m *Map) GetNeighbor(p point, d point) (point, int, bool) {
 | 
					 | 
				
			||||||
	return m.Get(p.add(d))
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
func (m *Map) Size() (int, int) {
 | 
					 | 
				
			||||||
	if m == nil || len(*m) == 0 {
 | 
					 | 
				
			||||||
		return 0, 0
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
	return len(*m), len((*m)[0])
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
func (m *Map) Neighbors(p point) []point {
 | 
					 | 
				
			||||||
	var lis []point
 | 
					 | 
				
			||||||
	for _, d := range []point{UP, DN, LF, RT} {
 | 
					 | 
				
			||||||
		if p, _, ok := m.GetNeighbor(p, d); ok {
 | 
					 | 
				
			||||||
			lis = append(lis, p)
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
	return lis
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
func (m *Map) NeighborDirections(p point) []point {
 | 
					 | 
				
			||||||
	var lis []point
 | 
					 | 
				
			||||||
	for _, d := range []point{UP, DN, LF, RT} {
 | 
					 | 
				
			||||||
		if m.Valid(p.add(d)) {
 | 
					 | 
				
			||||||
			lis = append(lis, d)
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
	return lis
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
func (m *Map) Valid(p point) bool {
 | 
					 | 
				
			||||||
	rows, cols := m.Size()
 | 
					 | 
				
			||||||
	return p[0] >= 0 && p[0] < rows && p[1] >= 0 && p[1] < cols
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
type memo struct {
 | 
					 | 
				
			||||||
	h int
 | 
					 | 
				
			||||||
	s int
 | 
					 | 
				
			||||||
	p point
 | 
					 | 
				
			||||||
	d point
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
func (memo) sort(a, b memo) bool {
 | 
					 | 
				
			||||||
	if a.h != b.h {
 | 
					 | 
				
			||||||
		return a.h < b.h
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	if a.s != b.s {
 | 
					 | 
				
			||||||
		return a.s < b.s
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	if a.p != b.p {
 | 
					 | 
				
			||||||
		return a.p.less(b.p)
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	return a.d.less(b.d)
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
type priorityQueue[T any, U []T] struct {
 | 
					 | 
				
			||||||
	elems U
 | 
					 | 
				
			||||||
	sort  func(a, b T) bool
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
func PriorityQueue[T any, U []T](sort func(a, b T) bool) *priorityQueue[T, U] {
 | 
					 | 
				
			||||||
	return &priorityQueue[T, U]{sort: sort}
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
func (pq *priorityQueue[T, U]) Enqueue(elem T) {
 | 
					 | 
				
			||||||
	pq.elems = append(pq.elems, elem)
 | 
					 | 
				
			||||||
	sort.Slice(pq.elems, func(i, j int) bool { return pq.sort(pq.elems[i], pq.elems[j]) })
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
func (pq *priorityQueue[T, I]) IsEmpty() bool {
 | 
					 | 
				
			||||||
	return len(pq.elems) == 0
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
func (pq *priorityQueue[T, I]) Dequeue() (T, bool) {
 | 
					 | 
				
			||||||
	var elem T
 | 
					 | 
				
			||||||
	if pq.IsEmpty() {
 | 
					 | 
				
			||||||
		return elem, false
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	elem, pq.elems = pq.elems[0], pq.elems[1:]
 | 
					 | 
				
			||||||
	return elem, true
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
func heuristic(m Map, p point) int {
 | 
					 | 
				
			||||||
	rows, cols := m.Size()
 | 
					 | 
				
			||||||
	return rows - p[0] + cols - p[1]
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
func search(m Map, minSize, maxSize int) int {
 | 
					 | 
				
			||||||
	rows, cols := m.Size()
 | 
					 | 
				
			||||||
	END := point{rows - 1, cols - 1}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	visited := make(map[vector]int)
 | 
					 | 
				
			||||||
	pq := PriorityQueue(memo{}.sort)
 | 
					 | 
				
			||||||
	pq.Enqueue(memo{h: heuristic(m, point{0, 0}), p: point{0, 0}, d: DN})
 | 
					 | 
				
			||||||
	
 | 
					 | 
				
			||||||
	for !pq.IsEmpty() {
 | 
					 | 
				
			||||||
		mem, _ := pq.Dequeue()
 | 
					 | 
				
			||||||
		fmt.Println(mem)
 | 
					 | 
				
			||||||
		if mem.h > dmap(visited, vector{mem.p[0], mem.p[1], mem.d[0], mem.d[1]}, INF) {
 | 
					 | 
				
			||||||
			continue
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		if mem.p == END {
 | 
					 | 
				
			||||||
			return mem.s
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		for _, nd := range m.NeighborDirections(mem.p) {
 | 
					 | 
				
			||||||
			if nd[0] == 0 && mem.d == RT || nd[1] == 0 && mem.d == DN {
 | 
					 | 
				
			||||||
				continue
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
			dscore := 0
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
			for _, size := range irange(1, maxSize+1) {
 | 
					 | 
				
			||||||
				np := mem.p.add(nd.scale(size))
 | 
					 | 
				
			||||||
				_, s, ok := m.Get(np)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
				if !ok {
 | 
					 | 
				
			||||||
					break
 | 
					 | 
				
			||||||
				}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
				dscore += s
 | 
					 | 
				
			||||||
				pscore := mem.s + dscore
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
				nh := heuristic(m, np) + pscore
 | 
					 | 
				
			||||||
				vec := vector{np[0], np[1], nd[0], nd[1]}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
				if size >= minSize && nh < dmap(visited, vec, INF) {
 | 
					 | 
				
			||||||
					pq.Enqueue(memo{nh, pscore, np, nd})
 | 
					 | 
				
			||||||
					visited[vec] = nh
 | 
					 | 
				
			||||||
				}
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	return 0
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
func dmap[K comparable, V any](m map[K]V, k K, d V) V {
 | 
					 | 
				
			||||||
	if v, ok := m[k]; ok {
 | 
					 | 
				
			||||||
		return v
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
	return d
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
func irange(a, b int) []int {
 | 
					 | 
				
			||||||
	lis := make([]int, b-a)
 | 
					 | 
				
			||||||
	for i := range lis {
 | 
					 | 
				
			||||||
		lis[i] = i + a
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
	return lis
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
type point [2]int
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
func (p point) add(a point) point { return point{p[0] + a[0], p[1] + a[1]} }
 | 
					 | 
				
			||||||
func (p point) scale(m int) point { return point{p[0] * m, p[1] * m} }
 | 
					 | 
				
			||||||
func (p point) less(a point) bool { return p[0] < a[0] || p[1] < a[1] }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
type vector [4]int
 | 
					 | 
				
			||||||
@ -1,41 +0,0 @@
 | 
				
			|||||||
package main
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import (
 | 
					 | 
				
			||||||
	"bufio"
 | 
					 | 
				
			||||||
	"bytes"
 | 
					 | 
				
			||||||
	"testing"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	_ "embed"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	"github.com/matryer/is"
 | 
					 | 
				
			||||||
)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
//go:embed example.txt
 | 
					 | 
				
			||||||
var example []byte
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
//go:embed input.txt
 | 
					 | 
				
			||||||
var input []byte
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
func TestExample(t *testing.T) {
 | 
					 | 
				
			||||||
	is := is.New(t)
 | 
					 | 
				
			||||||
	scan := bufio.NewScanner(bytes.NewReader(example))
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	result, err := run(scan)
 | 
					 | 
				
			||||||
	is.NoErr(err)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	t.Log(result)
 | 
					 | 
				
			||||||
	is.Equal(result.valuePT1, 102)
 | 
					 | 
				
			||||||
	is.Equal(result.valuePT2, 94)
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
func TestSolution(t *testing.T) {
 | 
					 | 
				
			||||||
	is := is.New(t)
 | 
					 | 
				
			||||||
	scan := bufio.NewScanner(bytes.NewReader(input))
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	result, err := run(scan)
 | 
					 | 
				
			||||||
	is.NoErr(err)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	t.Log(result)
 | 
					 | 
				
			||||||
	is.Equal(result.valuePT1, 843)
 | 
					 | 
				
			||||||
	is.Equal(result.valuePT2, 1017)
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
							
								
								
									
										5
									
								
								day20/example1.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								day20/example1.txt
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,5 @@
 | 
				
			|||||||
 | 
					broadcaster -> a, b, c
 | 
				
			||||||
 | 
					%a -> b
 | 
				
			||||||
 | 
					%b -> c
 | 
				
			||||||
 | 
					%c -> inv
 | 
				
			||||||
 | 
					&inv -> a
 | 
				
			||||||
							
								
								
									
										5
									
								
								day20/example2.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								day20/example2.txt
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,5 @@
 | 
				
			|||||||
 | 
					broadcaster -> a
 | 
				
			||||||
 | 
					%a -> inv, con
 | 
				
			||||||
 | 
					&inv -> b
 | 
				
			||||||
 | 
					%b -> con
 | 
				
			||||||
 | 
					&con -> output
 | 
				
			||||||
							
								
								
									
										58
									
								
								day20/input.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										58
									
								
								day20/input.txt
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,58 @@
 | 
				
			|||||||
 | 
					%vg -> lf, vd
 | 
				
			||||||
 | 
					%dr -> kg
 | 
				
			||||||
 | 
					%cn -> mv, pt
 | 
				
			||||||
 | 
					%rq -> bk, gr
 | 
				
			||||||
 | 
					%vp -> lp, bk
 | 
				
			||||||
 | 
					%kg -> lv
 | 
				
			||||||
 | 
					%lv -> jc, tp
 | 
				
			||||||
 | 
					%sj -> rm, vd
 | 
				
			||||||
 | 
					%jc -> tp, qr
 | 
				
			||||||
 | 
					%km -> tp, dr
 | 
				
			||||||
 | 
					%jx -> cn
 | 
				
			||||||
 | 
					&vd -> tf, lf, nb, cx, hx, lr
 | 
				
			||||||
 | 
					%lp -> jt, bk
 | 
				
			||||||
 | 
					%vj -> ps
 | 
				
			||||||
 | 
					broadcaster -> km, lr, xh, rf
 | 
				
			||||||
 | 
					%dj -> pt, gc
 | 
				
			||||||
 | 
					%cg -> vd, hx
 | 
				
			||||||
 | 
					&ln -> tg
 | 
				
			||||||
 | 
					%fl -> pt, sk
 | 
				
			||||||
 | 
					%lm -> tr, bk
 | 
				
			||||||
 | 
					%lr -> vd, vg
 | 
				
			||||||
 | 
					&pt -> vq, rf, cm, jx, rg
 | 
				
			||||||
 | 
					%cx -> gp
 | 
				
			||||||
 | 
					%gp -> vd, sj
 | 
				
			||||||
 | 
					&db -> tg
 | 
				
			||||||
 | 
					%st -> vd
 | 
				
			||||||
 | 
					%jt -> bk
 | 
				
			||||||
 | 
					%jh -> lm, bk
 | 
				
			||||||
 | 
					%xf -> bd, tp
 | 
				
			||||||
 | 
					%gc -> cm, pt
 | 
				
			||||||
 | 
					&tp -> dr, km, kg, db, vj, qr
 | 
				
			||||||
 | 
					%ps -> xf, tp
 | 
				
			||||||
 | 
					%rf -> pt, dj
 | 
				
			||||||
 | 
					%lf -> nb
 | 
				
			||||||
 | 
					%bd -> tp, gg
 | 
				
			||||||
 | 
					%dk -> tp, vj
 | 
				
			||||||
 | 
					%mn -> jh, bk
 | 
				
			||||||
 | 
					&tg -> rx
 | 
				
			||||||
 | 
					%ql -> bk, zx
 | 
				
			||||||
 | 
					%tr -> bk, vp
 | 
				
			||||||
 | 
					%sk -> pt
 | 
				
			||||||
 | 
					%nb -> cg
 | 
				
			||||||
 | 
					%sb -> vd, cx
 | 
				
			||||||
 | 
					%qr -> dk
 | 
				
			||||||
 | 
					%xh -> bk, ql
 | 
				
			||||||
 | 
					%rg -> sd
 | 
				
			||||||
 | 
					%hx -> sb
 | 
				
			||||||
 | 
					%sd -> pt, jx
 | 
				
			||||||
 | 
					%gr -> bk, mn
 | 
				
			||||||
 | 
					%gg -> tp
 | 
				
			||||||
 | 
					%zx -> rq
 | 
				
			||||||
 | 
					&bk -> xh, ln, zx
 | 
				
			||||||
 | 
					%rm -> st, vd
 | 
				
			||||||
 | 
					%hq -> fl, pt
 | 
				
			||||||
 | 
					&vq -> tg
 | 
				
			||||||
 | 
					%cm -> rg
 | 
				
			||||||
 | 
					&tf -> tg
 | 
				
			||||||
 | 
					%mv -> pt, hq
 | 
				
			||||||
							
								
								
									
										282
									
								
								day20/main.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										282
									
								
								day20/main.go
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,282 @@
 | 
				
			|||||||
 | 
					package main
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import (
 | 
				
			||||||
 | 
						"bufio"
 | 
				
			||||||
 | 
						_ "embed"
 | 
				
			||||||
 | 
						"fmt"
 | 
				
			||||||
 | 
						"strings"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						aoc "go.sour.is/advent-of-code"
 | 
				
			||||||
 | 
						"golang.org/x/exp/maps"
 | 
				
			||||||
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// var log = aoc.Log
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func main() { aoc.MustResult(aoc.Runner(run)) }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					type result struct {
 | 
				
			||||||
 | 
						valuePT1 int
 | 
				
			||||||
 | 
						valuePT2 int
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func (r result) String() string { return fmt.Sprintf("%#v", r) }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func run(scan *bufio.Scanner) (*result, error) {
 | 
				
			||||||
 | 
						m := &machine{}
 | 
				
			||||||
 | 
						receivers := make(map[string][]string)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						for scan.Scan() {
 | 
				
			||||||
 | 
							text := scan.Text()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							name, text, _ := strings.Cut(text, " -> ")
 | 
				
			||||||
 | 
							dest := strings.Split(text, ", ")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							switch {
 | 
				
			||||||
 | 
							case name == "broadcaster":
 | 
				
			||||||
 | 
								m.Add(name, &broadcaster{dest: dest})
 | 
				
			||||||
 | 
							case strings.HasPrefix(name, "%"):
 | 
				
			||||||
 | 
								name = strings.TrimPrefix(name, "%")
 | 
				
			||||||
 | 
								m.Add(name, &flipflop{name: name, dest: dest})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							case strings.HasPrefix(name, "&"):
 | 
				
			||||||
 | 
								name = strings.TrimPrefix(name, "&")
 | 
				
			||||||
 | 
								m.Add(name, &conjunction{name: name, dest: dest})
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							for _, d := range dest {
 | 
				
			||||||
 | 
								// rx is present so enable pt 2
 | 
				
			||||||
 | 
								if d == "rx" {
 | 
				
			||||||
 | 
									m.Add("rx", &rx{})
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
								receivers[d] = append(receivers[d], name)
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						m.setup(receivers)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						result := &result{}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						for i := 0; i < 10_000; i++ { // need enough presses to find the best LCM values for each conjunction
 | 
				
			||||||
 | 
							if i == 1000 {
 | 
				
			||||||
 | 
								result.valuePT1 = m.highPulses * m.lowPulses
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							m.Push(i)
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						// rx is present.. perform part 2.
 | 
				
			||||||
 | 
						if rx, ok := receivers["rx"]; ok {
 | 
				
			||||||
 | 
							tip := m.m[rx[0]].(*conjunction) // panic if missing!
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							var lvalues []int
 | 
				
			||||||
 | 
							for k, v := range tip.pushes {
 | 
				
			||||||
 | 
								for i, h := range makeHistory(v) {
 | 
				
			||||||
 | 
									if i == 1 && len(h) > 0 && h[0] > 0 {
 | 
				
			||||||
 | 
										fmt.Println(tip.name, k, "frequency", h[0])
 | 
				
			||||||
 | 
										lvalues = append(lvalues, h[0])
 | 
				
			||||||
 | 
									}
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							result.valuePT2 = aoc.LCM(lvalues...)
 | 
				
			||||||
 | 
							fmt.Println(tip.name, "LCM", result.valuePT2, lvalues)
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						return result, nil
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					type signal bool
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const (
 | 
				
			||||||
 | 
						LOW  signal = false
 | 
				
			||||||
 | 
						HIGH signal = true
 | 
				
			||||||
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					type message struct {
 | 
				
			||||||
 | 
						signal
 | 
				
			||||||
 | 
						from, to string
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					type machine struct {
 | 
				
			||||||
 | 
						m map[string]pulser
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						queue []message
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						press      int
 | 
				
			||||||
 | 
						highPulses int
 | 
				
			||||||
 | 
						lowPulses  int
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func (m *machine) Add(name string, p pulser) {
 | 
				
			||||||
 | 
						if m.m == nil {
 | 
				
			||||||
 | 
							m.m = make(map[string]pulser)
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						p.SetMachine(m)
 | 
				
			||||||
 | 
						m.m[name] = p
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					func (m *machine) Send(msgs ...message) {
 | 
				
			||||||
 | 
						m.queue = append(m.queue, msgs...)
 | 
				
			||||||
 | 
						for _, msg := range msgs {
 | 
				
			||||||
 | 
							// fmt.Println(msg)
 | 
				
			||||||
 | 
							if msg.signal {
 | 
				
			||||||
 | 
								m.highPulses++
 | 
				
			||||||
 | 
							} else {
 | 
				
			||||||
 | 
								m.lowPulses++
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					func (m *machine) Push(i int) {
 | 
				
			||||||
 | 
						m.press = i
 | 
				
			||||||
 | 
						m.Send(generate(LOW, "button", "broadcaster")...)
 | 
				
			||||||
 | 
						m.processQueue(i)
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					func (m *machine) processQueue(i int) {
 | 
				
			||||||
 | 
						// look for work and process up to the queue length. repeat.
 | 
				
			||||||
 | 
						hwm := 0
 | 
				
			||||||
 | 
						for hwm < len(m.queue) {
 | 
				
			||||||
 | 
							end := len(m.queue)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							for ; hwm < end; hwm++ {
 | 
				
			||||||
 | 
								msg := m.queue[hwm]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								if p, ok := m.m[msg.to]; ok {
 | 
				
			||||||
 | 
									// fmt.Println(i, "S:", m.m[msg.from], msg.signal, "R:", p)
 | 
				
			||||||
 | 
									p.Pulse(msg)
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							hwm = 0
 | 
				
			||||||
 | 
							copy(m.queue, m.queue[end:])
 | 
				
			||||||
 | 
							m.queue = m.queue[:len(m.queue)-end]
 | 
				
			||||||
 | 
							// fmt.Println("")
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					func (m *machine) setup(receivers map[string][]string) {
 | 
				
			||||||
 | 
						for name, recv := range receivers {
 | 
				
			||||||
 | 
							if p, ok := m.m[name]; ok {
 | 
				
			||||||
 | 
								if p, ok := p.(interface{ Receive(...string) }); ok {
 | 
				
			||||||
 | 
									p.Receive(recv...)
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					type pulser interface {
 | 
				
			||||||
 | 
						Pulse(message)
 | 
				
			||||||
 | 
						SetMachine(*machine)
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// IsModule implements the machine registration for each module.
 | 
				
			||||||
 | 
					type IsModule struct {
 | 
				
			||||||
 | 
						*machine
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func (p *IsModule) SetMachine(m *machine) { p.machine = m }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					type broadcaster struct {
 | 
				
			||||||
 | 
						dest []string
 | 
				
			||||||
 | 
						IsModule
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func (b *broadcaster) Pulse(msg message) {
 | 
				
			||||||
 | 
						b.Send(generate(msg.signal, "broadcaster", b.dest...)...)
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					type flipflop struct {
 | 
				
			||||||
 | 
						name  string
 | 
				
			||||||
 | 
						state signal
 | 
				
			||||||
 | 
						dest  []string
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						IsModule
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func (b *flipflop) Pulse(msg message) {
 | 
				
			||||||
 | 
						if !msg.signal {
 | 
				
			||||||
 | 
							b.state = !b.state
 | 
				
			||||||
 | 
							b.Send(generate(b.state, b.name, b.dest...)...)
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					type conjunction struct {
 | 
				
			||||||
 | 
						name  string
 | 
				
			||||||
 | 
						state map[string]signal
 | 
				
			||||||
 | 
						dest  []string
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						pushes map[string][]int
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						IsModule
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func (b *conjunction) Receive(names ...string) {
 | 
				
			||||||
 | 
						if b.state == nil {
 | 
				
			||||||
 | 
							b.state = make(map[string]signal)
 | 
				
			||||||
 | 
							b.pushes = make(map[string][]int)
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						for _, name := range names {
 | 
				
			||||||
 | 
							b.state[name] = false
 | 
				
			||||||
 | 
							b.pushes[name] = []int{}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					func (b *conjunction) Pulse(msg message) {
 | 
				
			||||||
 | 
						b.state[msg.from] = msg.signal
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if msg.signal {
 | 
				
			||||||
 | 
							// collect frequency of pushes to esti,ate rate
 | 
				
			||||||
 | 
							b.pushes[msg.from] = append(b.pushes[msg.from], b.press)
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if all(HIGH, maps.Values(b.state)...) {
 | 
				
			||||||
 | 
							b.Send(generate(LOW, b.name, b.dest...)...)
 | 
				
			||||||
 | 
							return
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						b.Send(generate(HIGH, b.name, b.dest...)...)
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					type rx struct {
 | 
				
			||||||
 | 
						IsModule
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func (rx *rx) Pulse(msg message) {
 | 
				
			||||||
 | 
						if !msg.signal {
 | 
				
			||||||
 | 
							panic("pulse received") // will never happen...
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// helper funcs
 | 
				
			||||||
 | 
					func all[T comparable](match T, lis ...T) bool {
 | 
				
			||||||
 | 
						for _, b := range lis {
 | 
				
			||||||
 | 
							if b != match {
 | 
				
			||||||
 | 
								return false
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						return true
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					func generate(t signal, from string, destinations ...string) []message {
 | 
				
			||||||
 | 
						msgs := make([]message, len(destinations))
 | 
				
			||||||
 | 
						for i, to := range destinations {
 | 
				
			||||||
 | 
							msgs[i] = message{signal: t, from: from, to: to}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						return msgs
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// makeHistory from day 9
 | 
				
			||||||
 | 
					func makeHistory(in []int) [][]int {
 | 
				
			||||||
 | 
						var history [][]int
 | 
				
			||||||
 | 
						history = append(history, in)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						// for {
 | 
				
			||||||
 | 
						var diffs []int
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						current := history[len(history)-1]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						for i := range current[1:] {
 | 
				
			||||||
 | 
							diffs = append(diffs, current[i+1]-current[i])
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						history = append(history, diffs)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						// if len(diffs) == 0 || aoc.Max(diffs[0], diffs[1:]...) == 0 && aoc.Min(diffs[0], diffs[1:]...) == 0 {
 | 
				
			||||||
 | 
						// 	break
 | 
				
			||||||
 | 
						// }
 | 
				
			||||||
 | 
						// }
 | 
				
			||||||
 | 
						return history
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
							
								
								
									
										56
									
								
								day20/main_test.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										56
									
								
								day20/main_test.go
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,56 @@
 | 
				
			|||||||
 | 
					package main
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import (
 | 
				
			||||||
 | 
						"bufio"
 | 
				
			||||||
 | 
						"bytes"
 | 
				
			||||||
 | 
						"testing"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						_ "embed"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						"github.com/matryer/is"
 | 
				
			||||||
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					//go:embed example1.txt
 | 
				
			||||||
 | 
					var example1 []byte
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					//go:embed example2.txt
 | 
				
			||||||
 | 
					var example2 []byte
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					//go:embed input.txt
 | 
				
			||||||
 | 
					var input []byte
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func TestExample1(t *testing.T) {
 | 
				
			||||||
 | 
						is := is.New(t)
 | 
				
			||||||
 | 
						scan := bufio.NewScanner(bytes.NewReader(example1))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						result, err := run(scan)
 | 
				
			||||||
 | 
						is.NoErr(err)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						t.Log(result)
 | 
				
			||||||
 | 
						is.Equal(result.valuePT1, 32000000)
 | 
				
			||||||
 | 
						is.Equal(result.valuePT2, 0)
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func TestExample2(t *testing.T) {
 | 
				
			||||||
 | 
						is := is.New(t)
 | 
				
			||||||
 | 
						scan := bufio.NewScanner(bytes.NewReader(example2))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						result, err := run(scan)
 | 
				
			||||||
 | 
						is.NoErr(err)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						t.Log(result)
 | 
				
			||||||
 | 
						is.Equal(result.valuePT1, 11687500)
 | 
				
			||||||
 | 
						is.Equal(result.valuePT2, 0)
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func TestSolution(t *testing.T) {
 | 
				
			||||||
 | 
						is := is.New(t)
 | 
				
			||||||
 | 
						scan := bufio.NewScanner(bytes.NewReader(input))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						result, err := run(scan)
 | 
				
			||||||
 | 
						is.NoErr(err)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						t.Log(result)
 | 
				
			||||||
 | 
						is.Equal(result.valuePT1, 819397964)
 | 
				
			||||||
 | 
						is.Equal(result.valuePT2, 252667369442479)
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user