diff --git a/data/day-008 b/data/day-008 new file mode 100644 index 0000000..f38a7de --- /dev/null +++ b/data/day-008 @@ -0,0 +1,99 @@ +332003300013411421030123310000325304355245416315402454123304251100551413414301042114403240340202013 +130120131034131214123330450045513234151453520504226501101432120555550112535000130014212133321332113 +221120234102441024240343113122535350650301140511165442365451334130334102412103112220300240240410033 +201003103341210433533532125351404201522621325222421563264456331504145322423000453224222123321220333 +031230441334332445422025052033156043024163224106103336113645142121364161131252032003041114411412021 +220020011034120131030421351112001560056302340102663363436621063030163253101311044513331310020121210 +303040332431011132533443553321623462145336356503166211061351546411261306522112352524223111304442113 +222232314244103121400531144211642025551410166524434251333155410020524252654152222025520123303142134 +042224141010553350340352020211461062016047171732434651455473401346405306461643421210440205441310240 +131414414351042410204054060152045335375171544547253174334561651556000661445663062351033351130040204 +421330222101314443436633206550451571441147331752243741723515751137750300263144202141521145051242430 +304413012541454453626212024316241455547757536354351542142777234173745662454551154032335331331021134 +210210020432025225546350564503461126533444677377311761441622516326645176426625622336441140312530032 +321331544225031511163062251235515725645116556552716447134611121422154147221206525245321405031141022 +132304244223434034644164163431246762324642345277558431347372614572744147525404511143400153134025230 +433014255554304626035066241262275264471542552344752837378423431364621367116254664210141202530542210 +341013013022206652606231157612322543268825577322777368835244322537337447537335222426156022255415144 +441525355153361333331104577746612725264233863646327752763365353845325222561423350253602520443533440 +331325510313351211266777763761227567864572264785467455456335374866514554722241446502256653043414352 +223021111542064104141467134673114548632465363887386464736623733276867135422463573365121002544203051 +234440212451036151623744516551447238632584877658432527675226444645478351316311314130326060612445003 +033044450411501311543214676112356456332628328268867775386867238847585733154276434130400024043455141 +205131331521440160315623445652882338268255429855577746736386265847343838432324621120436063113151534 +140402552431642627426711567572286656272365849859756599936647555338227372237714366515211422436232144 +200320133113652127237741127458347233869549439984447347799396896884254487755137323273723662433004102 +454424155234224212665443255248273448987696973685793654947967344658738363223344343225642564053032543 +204042231254546227227173383425466368946763933885435669749596368564787364536585763761277210314664203 +000413654454332177326723345672532779349633764356436834584654668495657884625378221164774505026425413 +104211300205311715275673636382227444595567898434345599648544779845678768388347314614742310641262315 +314445336034346211516832335578373876466544933499649884577395587843454938885463235516577345221004303 +312454541364371767524685754878934666577363898489498779648546864385644596874462483134516113200642424 +045303023541545211177774473328459887983569477675788545664497958663479946723273556551566745654414551 +315104421032435152386476237653439634759548869484955567445998495777843384344352472827152536033066153 +005541041351421165773462627984936336589775654486658558888479674838753737875276667512234774606631641 +342465056121667145785833876599887748648776987865445984558545644948958639677226254687646734301231545 +550456224133553143372382765354534539768845445646854596849896894999799849377256565255732636263050651 +252500660515557345284865448359656747876866486595579856584858769494858684374873544562312172202212334 +052616136615134615787657448653579745658966465855689959587489489794773794834525445883123525523333601 +252230540571447783264468947593555864557685577987986869757576675658486967664678685272326377531121454 +413163451427745626242667677845887769799976669995586696577985969684648578656883457628861571436025642 +533405114525476142726689645385596554758496765765598795556989875896575787974383873637675463761256614 +454326344554154642756573364987695594479865587966585689568895957855974975333548887427326446522203044 +216114153574223527762678337544477597569767966689859979656975697545485575737839438443886132712045365 +125156666622272632365556785997895855986558977786966869968767985974484866833363785734652313512061636 +322321415352243487443396957878886784758759777788777677655788869779499684595638364356883237212251446 +122013647613644872445494688665557499576659588698877977985696986649564754335394787334241464246322355 +605654146537634766832593985758685444759955657999799769877988857994746676947396585553386542761263544 +213653425317331334336886398546858769868586766969966669676559789578969885393464626654824257614332425 +660654431433636254452474779474874757675959989699776669987955967958545665666456488723857762667632624 +302316342766454766363278374838448478956968676979999687797875698557444688784488876226726637647532365 +636242311725575834473585863576767447899876977687688888867867959567798495435865837265222631673466406 +062235543254168266743397385348444696655777679668976789966989675764697759836733964552835613545462646 +640333544126212773487299459967465446887655668986886976666767658875567556473478954563422657411264042 +540625433215572383378434996869859464995669567997788969786675997787457759898479882426636752542310414 +445535166771723352824654693847865478896865796669698987668955589559967975639596952255564346215524205 +221425127235511746738568359348455498598575855997977899887788556776765485458747726328451547753230153 +214532604757232738234837789469967949479868968786789687989865889988588497583593337657226241341115620 +004244467622352758548665446367486478788877985697798995669999777644666456469933826356824242327113564 +266353354374115362785466543499745995759668555669555957566778696566987598783854846782725636654233143 +531631243311643228822426956378987478954886887766685959675789555656676595553996574356555472444216454 +140666423163211644345466589664758965767788585865675857896579844968677958746766768557511213772051231 +234421130317541287775845944673487775548876959858669796556656565784695558999352648657476544226554635 +412624633546563177676442768954956647579597689996578669686556674944546967458667638377245761312144410 +352621121571142172762553299483794557966844949979766996656658586465459334647545764377443526446306142 +006346322575555262872376536466933545779748779879878867649456994569974998665447554338732211431303113 +554334563237315531875257467895335488595964994888856875774884857555594969967225623822432356664611145 +451004264172434426643257788958894598687845878998475494658586487656436966346528627424414757464352412 +221050361362741524742282864394477367968877699857448774499568854837979743562628644665437676533622521 +355255324661136164174557438655596744798777687569864749968955695944564933443722484772514174556311265 +430065024241631523322743433843653488937876477676994649678667784553585674765334237555126451026263325 +235505456452451176728742366547446897648939846457559957659763984484633798325463455573553116236021123 +115234031514534736163577244834455659564966385864459866983788898754869654436588443511424124332535540 +351404033625617526367482264456275584336747746958739743757367759776843883862727732164231653501306242 +503055012541653215346262842272827896834747967447549377968493597455838645446365744773157220423462223 +553143615436255477475667832483727897549434843838855833978798965894468635542322233222537021036615034 +002222462560346626774546373548542854933338778555785475683957754684227337526515767775450220143425433 +131504260406323354665445316566825527286679849878744668534384467583656384425625441776212266506542432 +215054255514263012751367165784852227765689933769757763433568352646878327626173155737352644405300343 +552314225454222510753211174655762567463268427333439583897865725467264347257215367462301306160354104 +255302200521051251765326645715455744274263586466448448464856568583488367547737246743335131401512412 +101245322521566243614773147142427484788364664826554268425888478476726656461566577523262156415054432 +442223113356204112601267136315116673824647668456465767535574488583325342131741417460621414452243501 +030021515554410652516146332263743763547244733553874755783747688225247344423456213264214215420224550 +413231405342104505430605655136127652642884747258725854637357624386534551152676140060146342324553214 +043025432315263603012410724771723562544436732537283686754328266144444737731263642624006034433532321 +104334254513411453146423047163424563275165826658888562874364647322215523235751010535365201041550134 +300020553012410516650503127144151151366257317647264676757751532461215753567001666406110512441403243 +102330504341544132334643313664461577763552415276253277551421216256257366432140103125631532553012441 +133121400000310324062254440466672675621365462615365334463422371553612311060246343023025050324513003 +414433432204250221550404116102162474676751443756673535654632655537372506016342016305523520322020433 +300431421523212003523352645563411534764236144446653634512147234367106145251253516223042015230414132 +243312200244203131000464166042310223354312441365122363622347664211452666653252200441444455224101342 +234101331402523132440002366305604106515143667473324626357574660410555433104644155051000114411404322 +323231340213153413415545102230611245662526641323132514750054002302435343103551525112155333241003331 +011130141043235255230523325530536445442030625261123460622614140226632004323354541551014140002214411 +102244200240002203012052520545350235023153142054205355115153522126310220541122512230331031112130111 +013231143131433131124534302204532206566450455256355310122012430310255401351304225525542241003133010 +132200122232433121333410132153131541542513264261463154353021340403623114231305043110312440012243111 +001320030221212412130340411450015410126162032430413232552634423102222044153052245310344121344231122 diff --git a/data/day-009 b/data/day-009 new file mode 100644 index 0000000..704e4cd --- /dev/null +++ b/data/day-009 @@ -0,0 +1,2000 @@ +L 1 +D 2 +L 2 +U 2 +D 2 +U 2 +D 1 +R 1 +U 1 +R 1 +L 2 +R 1 +U 1 +R 2 +L 1 +D 2 +R 2 +L 2 +D 1 +U 2 +R 2 +L 1 +U 2 +D 2 +U 2 +D 2 +L 1 +R 2 +L 1 +R 1 +L 1 +D 2 +L 1 +U 1 +L 2 +U 1 +L 2 +R 2 +D 1 +L 2 +R 1 +D 1 +U 1 +L 1 +U 2 +D 2 +L 1 +U 1 +R 2 +D 1 +L 1 +U 1 +R 2 +D 1 +R 2 +D 2 +U 2 +R 2 +U 2 +R 1 +L 1 +R 1 +L 1 +D 1 +U 1 +R 2 +D 2 +L 2 +U 1 +D 1 +R 1 +U 1 +L 1 +D 2 +U 2 +D 1 +L 2 +U 1 +D 1 +L 2 +U 1 +R 2 +D 1 +L 1 +R 1 +L 1 +D 1 +L 1 +R 1 +L 2 +R 2 +D 1 +R 2 +D 1 +L 1 +D 1 +L 2 +R 2 +U 2 +L 2 +R 1 +U 2 +R 2 +D 1 +U 1 +L 2 +D 2 +U 2 +L 2 +R 1 +U 2 +D 2 +L 3 +D 1 +R 2 +D 2 +U 2 +L 3 +U 1 +D 1 +R 1 +D 2 +L 2 +D 2 +R 3 +D 1 +U 1 +L 3 +R 2 +L 1 +U 2 +D 1 +R 1 +U 1 +D 1 +L 3 +U 3 +R 3 +U 1 +L 1 +U 1 +R 3 +U 3 +L 2 +R 1 +L 2 +U 1 +R 3 +L 3 +U 1 +D 2 +U 3 +R 3 +D 1 +L 1 +R 2 +L 1 +U 1 +R 2 +D 1 +U 1 +D 1 +R 3 +D 3 +R 1 +U 3 +D 2 +R 2 +L 2 +U 1 +R 2 +U 2 +D 2 +R 1 +U 1 +R 3 +D 2 +U 1 +D 2 +L 3 +R 3 +U 3 +R 3 +L 3 +U 3 +L 2 +R 1 +U 2 +D 2 +R 2 +L 1 +U 3 +L 2 +U 1 +R 1 +U 3 +D 3 +R 2 +L 1 +U 3 +D 3 +L 2 +R 2 +D 3 +L 3 +R 2 +D 3 +U 3 +L 1 +D 1 +L 2 +R 3 +U 2 +D 2 +U 3 +R 2 +L 2 +U 3 +D 1 +L 3 +U 1 +L 1 +U 1 +D 4 +L 3 +U 3 +D 2 +R 3 +U 4 +D 2 +U 1 +R 3 +L 4 +R 1 +D 2 +R 1 +D 4 +U 1 +D 3 +U 4 +L 3 +D 4 +R 1 +U 3 +R 1 +U 2 +L 2 +R 1 +D 2 +U 1 +D 4 +R 1 +D 1 +R 4 +L 2 +D 2 +R 2 +L 3 +U 1 +L 4 +D 1 +U 2 +L 4 +D 3 +R 4 +L 4 +D 3 +L 4 +R 1 +D 3 +U 1 +L 1 +D 4 +R 1 +U 4 +L 2 +U 3 +R 4 +L 4 +D 4 +U 3 +R 2 +U 2 +L 2 +R 1 +U 2 +L 3 +U 4 +D 4 +L 4 +R 4 +L 3 +D 4 +U 3 +L 3 +U 2 +L 3 +R 3 +D 4 +R 4 +L 1 +U 1 +R 1 +D 2 +U 3 +D 4 +L 4 +D 3 +U 4 +L 1 +R 4 +U 2 +D 4 +R 2 +L 3 +R 2 +U 4 +R 3 +U 1 +L 2 +U 4 +R 4 +L 1 +D 2 +R 1 +U 4 +R 4 +U 1 +L 1 +U 1 +R 1 +L 4 +U 2 +R 2 +L 5 +R 5 +L 1 +R 4 +U 5 +L 4 +R 3 +D 1 +R 4 +L 5 +R 2 +L 1 +R 5 +D 4 +R 4 +L 1 +U 2 +D 4 +U 4 +L 5 +D 3 +U 2 +D 5 +L 5 +D 3 +U 1 +R 5 +U 4 +R 1 +U 4 +D 1 +R 2 +D 2 +U 3 +D 3 +R 5 +U 2 +D 2 +U 5 +L 4 +R 1 +D 4 +U 3 +L 4 +D 1 +L 4 +D 5 +L 5 +U 3 +L 2 +R 4 +L 5 +U 2 +L 1 +D 5 +U 2 +R 5 +L 1 +D 2 +R 3 +D 5 +U 2 +D 3 +R 4 +L 3 +R 5 +L 5 +U 3 +L 2 +D 5 +U 5 +R 4 +U 5 +D 5 +L 1 +D 4 +U 4 +L 4 +U 3 +D 3 +L 2 +R 1 +L 5 +D 3 +L 1 +U 4 +D 5 +L 5 +R 1 +U 4 +D 5 +U 3 +D 5 +L 1 +R 5 +L 1 +D 3 +L 2 +D 3 +L 2 +D 2 +U 3 +D 2 +L 3 +R 2 +U 3 +L 4 +D 4 +U 4 +D 4 +R 2 +D 3 +U 4 +D 6 +L 2 +D 4 +U 4 +L 2 +D 4 +U 1 +D 1 +U 1 +R 3 +U 3 +L 1 +U 6 +R 5 +L 1 +U 5 +L 2 +D 1 +U 3 +D 2 +U 3 +D 2 +R 2 +U 6 +L 5 +D 4 +L 2 +D 6 +U 5 +D 3 +R 2 +L 6 +U 5 +R 2 +U 3 +L 2 +R 3 +D 6 +U 5 +D 1 +R 5 +L 3 +U 5 +R 3 +L 5 +R 3 +L 4 +U 6 +D 3 +U 6 +L 3 +R 5 +U 6 +L 1 +D 5 +L 3 +R 5 +L 3 +D 4 +R 4 +D 6 +L 1 +R 4 +U 4 +D 4 +U 5 +D 6 +L 6 +R 2 +L 4 +D 3 +R 4 +U 5 +L 5 +D 4 +R 6 +D 6 +R 2 +U 4 +D 5 +L 6 +R 3 +U 6 +R 6 +D 3 +R 6 +L 1 +D 3 +U 2 +R 2 +D 2 +U 6 +D 4 +U 5 +D 1 +L 6 +U 2 +D 4 +R 2 +D 3 +U 4 +L 1 +D 2 +L 2 +U 2 +D 3 +L 5 +U 6 +L 5 +R 2 +L 2 +D 7 +R 2 +D 6 +U 5 +L 4 +U 2 +R 1 +D 1 +L 7 +D 4 +R 2 +D 6 +U 4 +L 1 +U 2 +R 4 +D 4 +R 3 +L 3 +U 4 +R 3 +L 2 +U 6 +D 1 +L 3 +U 6 +D 2 +R 2 +L 5 +U 7 +R 5 +L 2 +D 5 +U 4 +D 3 +L 1 +D 5 +L 5 +U 4 +R 1 +D 4 +L 2 +D 7 +L 7 +D 3 +U 4 +L 5 +D 3 +L 7 +R 3 +D 4 +L 5 +R 7 +L 2 +U 4 +R 5 +L 2 +R 2 +D 1 +R 1 +U 3 +R 4 +L 1 +U 4 +L 2 +R 1 +U 4 +D 7 +U 2 +D 2 +R 2 +L 3 +D 3 +R 1 +L 2 +R 2 +U 6 +R 1 +U 1 +R 7 +U 3 +D 2 +L 5 +U 7 +D 7 +U 3 +L 2 +U 7 +R 3 +D 3 +U 2 +D 5 +R 6 +D 5 +U 1 +R 7 +D 6 +R 6 +U 3 +L 1 +R 6 +D 6 +R 1 +L 6 +R 6 +D 7 +R 3 +L 5 +R 5 +D 4 +U 7 +L 8 +D 2 +U 3 +D 5 +L 4 +D 2 +R 1 +L 5 +D 8 +U 6 +R 2 +D 2 +L 2 +R 3 +L 2 +R 3 +L 6 +R 4 +U 6 +D 7 +R 6 +L 7 +U 5 +L 6 +R 6 +D 5 +R 5 +D 5 +L 4 +D 4 +U 7 +L 3 +U 7 +L 4 +U 8 +R 7 +D 4 +L 2 +D 6 +R 2 +U 3 +L 6 +D 1 +R 4 +U 8 +D 3 +U 2 +L 6 +R 1 +L 2 +U 4 +L 1 +R 1 +U 8 +D 2 +L 5 +D 6 +L 5 +R 2 +L 5 +U 6 +D 1 +L 7 +U 4 +D 5 +L 3 +R 5 +D 5 +R 3 +L 2 +D 3 +L 3 +D 5 +L 8 +R 7 +D 5 +L 2 +R 3 +U 5 +L 1 +D 6 +R 5 +L 6 +R 1 +U 1 +R 4 +L 6 +U 1 +D 6 +L 7 +D 8 +R 1 +L 5 +D 2 +R 2 +D 2 +R 7 +L 7 +U 7 +R 4 +D 5 +R 4 +U 8 +R 3 +D 6 +R 1 +D 1 +U 8 +D 4 +U 7 +R 3 +L 9 +D 3 +L 9 +U 1 +R 5 +D 4 +U 7 +L 4 +U 4 +L 7 +R 1 +D 8 +R 4 +L 4 +U 4 +L 8 +U 5 +L 7 +D 4 +L 9 +D 2 +U 3 +L 3 +D 5 +U 1 +L 1 +R 6 +D 2 +L 1 +D 2 +L 3 +U 4 +L 6 +U 3 +R 5 +L 3 +D 7 +U 6 +L 6 +D 9 +L 5 +U 1 +R 9 +U 4 +R 1 +L 5 +U 9 +R 6 +D 7 +U 9 +L 4 +U 6 +D 7 +U 8 +L 1 +U 8 +R 4 +L 2 +R 3 +D 1 +U 6 +D 9 +L 8 +U 8 +L 9 +D 4 +R 8 +L 1 +D 9 +L 1 +R 7 +D 8 +U 6 +D 8 +R 9 +U 2 +R 3 +U 7 +R 8 +D 5 +L 6 +U 3 +D 8 +R 2 +U 5 +L 5 +R 9 +D 4 +U 1 +D 6 +L 1 +U 3 +R 4 +L 5 +R 1 +L 9 +R 4 +D 1 +L 9 +D 4 +U 7 +R 2 +D 8 +L 9 +R 5 +L 5 +D 7 +L 6 +D 6 +L 10 +U 8 +L 6 +D 6 +R 9 +D 10 +L 5 +R 8 +D 2 +U 7 +R 4 +U 5 +R 3 +L 6 +D 10 +L 7 +D 7 +U 9 +L 6 +R 10 +U 2 +L 3 +U 10 +D 3 +R 10 +D 4 +L 9 +R 2 +L 8 +R 4 +D 7 +R 10 +D 2 +U 9 +D 2 +R 7 +D 10 +R 10 +D 7 +R 5 +D 5 +R 7 +U 7 +D 10 +U 5 +D 3 +R 5 +U 10 +L 3 +D 7 +R 7 +U 7 +L 4 +U 3 +R 3 +D 7 +L 7 +U 2 +D 4 +L 5 +R 3 +U 5 +D 6 +R 2 +D 4 +U 2 +D 6 +U 7 +D 2 +L 2 +U 6 +D 9 +U 3 +D 1 +U 5 +D 2 +R 3 +L 6 +D 8 +L 7 +R 5 +L 4 +U 6 +L 9 +R 5 +D 5 +U 4 +D 6 +U 5 +D 1 +U 8 +D 2 +L 4 +R 5 +L 3 +U 10 +L 1 +R 10 +U 4 +R 5 +D 4 +R 8 +U 5 +L 2 +R 10 +L 10 +U 4 +D 3 +U 3 +R 4 +D 8 +R 9 +L 5 +R 5 +D 10 +L 11 +D 10 +L 6 +R 11 +L 2 +R 7 +U 6 +R 9 +L 10 +D 3 +R 6 +D 7 +L 10 +U 7 +D 2 +L 4 +D 1 +L 8 +D 7 +L 10 +R 2 +U 7 +L 9 +R 1 +D 1 +L 11 +U 11 +D 3 +R 4 +D 4 +U 11 +L 6 +D 2 +L 7 +D 6 +U 8 +L 1 +R 11 +L 1 +U 3 +D 8 +L 4 +D 11 +U 8 +R 4 +D 1 +R 5 +D 9 +L 2 +D 1 +U 4 +R 7 +L 6 +D 5 +U 1 +L 8 +U 6 +R 10 +D 11 +U 3 +D 1 +U 7 +D 9 +R 8 +D 4 +R 11 +L 5 +D 8 +L 8 +U 1 +R 10 +U 9 +D 7 +R 1 +D 9 +U 1 +R 3 +D 11 +L 9 +D 1 +R 2 +U 5 +R 8 +U 1 +L 8 +D 11 +U 9 +L 8 +U 1 +R 1 +D 1 +R 10 +D 3 +R 8 +U 10 +D 2 +U 6 +D 5 +R 5 +D 10 +R 7 +L 1 +R 10 +U 1 +D 8 +R 7 +D 10 +R 8 +U 2 +L 12 +D 1 +R 6 +D 7 +U 11 +L 8 +R 12 +D 3 +U 12 +L 11 +D 2 +R 3 +L 6 +U 1 +R 2 +L 5 +R 2 +U 8 +L 11 +R 4 +L 2 +R 3 +D 12 +R 4 +U 8 +R 5 +D 6 +R 9 +D 8 +R 7 +D 10 +R 5 +U 4 +L 6 +D 1 +U 6 +D 7 +R 2 +L 2 +R 8 +L 12 +R 7 +L 9 +U 10 +D 2 +R 9 +L 2 +D 10 +U 8 +R 9 +L 7 +D 1 +L 8 +R 4 +L 6 +D 11 +R 2 +L 6 +D 1 +R 6 +D 2 +R 11 +U 9 +R 10 +U 8 +L 4 +D 12 +L 4 +D 7 +R 5 +L 11 +D 2 +U 7 +D 1 +L 10 +R 3 +L 5 +U 12 +R 5 +L 8 +R 6 +L 10 +D 9 +U 8 +R 3 +D 12 +L 4 +D 7 +U 3 +D 11 +U 2 +D 11 +R 7 +D 5 +U 2 +D 8 +U 7 +R 2 +U 5 +D 1 +R 10 +D 7 +L 7 +R 4 +L 1 +U 12 +L 12 +D 9 +R 7 +U 9 +R 5 +L 3 +R 2 +U 11 +D 1 +L 10 +D 11 +R 1 +D 7 +R 7 +D 9 +R 13 +D 7 +L 9 +D 9 +R 13 +D 7 +R 9 +D 10 +U 7 +R 5 +L 1 +U 8 +D 9 +U 10 +L 5 +U 4 +D 9 +U 1 +L 8 +D 3 +U 7 +D 6 +U 2 +D 8 +L 12 +U 2 +R 11 +L 10 +R 9 +D 4 +L 4 +U 2 +L 11 +U 11 +R 6 +D 7 +L 2 +D 6 +R 9 +L 7 +D 6 +L 12 +U 12 +D 5 +R 1 +L 11 +U 12 +L 4 +D 4 +R 12 +U 6 +R 4 +U 6 +R 3 +L 3 +R 10 +D 6 +R 9 +D 12 +U 6 +D 3 +U 13 +D 13 +U 2 +D 10 +R 6 +L 10 +R 10 +L 13 +U 6 +D 12 +R 8 +D 8 +U 6 +D 1 +L 7 +R 7 +U 5 +R 4 +U 2 +D 8 +L 11 +D 13 +L 10 +U 3 +L 8 +U 6 +D 5 +R 8 +D 12 +U 13 +L 10 +U 12 +R 10 +U 9 +L 3 +D 10 +U 3 +R 2 +L 8 +D 4 +U 12 +L 13 +R 14 +U 13 +R 4 +L 7 +D 5 +L 12 +D 4 +L 9 +R 12 +D 10 +U 11 +R 7 +D 3 +R 5 +D 13 +R 11 +D 8 +R 4 +L 3 +R 11 +L 5 +D 7 +U 2 +D 8 +L 12 +R 2 +D 10 +U 11 +D 6 +L 9 +D 8 +R 3 +D 9 +L 9 +D 6 +R 10 +U 5 +D 2 +R 9 +U 5 +D 7 +L 1 +D 14 +U 2 +R 14 +U 11 +D 4 +L 8 +R 8 +D 2 +L 3 +U 4 +R 2 +U 5 +R 6 +U 8 +R 2 +L 4 +D 1 +L 9 +U 13 +D 12 +R 7 +L 6 +R 10 +U 12 +L 14 +U 3 +L 6 +D 12 +R 13 +L 13 +U 5 +L 5 +R 6 +L 11 +R 7 +L 6 +D 14 +U 2 +D 12 +L 2 +R 9 +U 4 +L 14 +U 12 +R 12 +D 3 +L 5 +R 8 +D 10 +R 13 +D 6 +U 9 +R 10 +L 14 +D 4 +L 6 +D 8 +L 12 +U 10 +L 11 +D 3 +U 2 +R 2 +L 13 +R 6 +L 3 +R 14 +D 7 +R 3 +D 14 +R 3 +L 1 +D 15 +L 6 +U 6 +R 3 +D 12 +U 11 +R 10 +D 10 +L 2 +R 1 +U 7 +D 2 +L 7 +D 13 +R 9 +U 6 +R 6 +D 7 +R 3 +L 14 +R 2 +L 10 +D 13 +U 8 +R 3 +U 12 +R 10 +L 12 +R 11 +U 6 +L 13 +R 1 +D 14 +U 13 +D 13 +U 1 +L 10 +R 2 +D 4 +U 1 +L 7 +U 2 +D 9 +R 9 +U 7 +L 9 +D 7 +U 2 +R 1 +D 13 +U 3 +L 1 +U 3 +D 15 +U 6 +R 8 +L 6 +U 6 +L 8 +D 1 +U 4 +R 15 +L 13 +R 3 +L 15 +D 4 +R 10 +L 14 +U 2 +L 3 +R 7 +L 12 +R 15 +U 7 +D 2 +U 15 +R 12 +D 12 +L 6 +D 8 +R 5 +L 14 +R 8 +U 1 +D 5 +U 1 +L 3 +R 2 +U 9 +L 5 +U 8 +L 2 +U 1 +R 5 +D 3 +L 4 +R 15 +U 15 +L 6 +D 12 +U 9 +D 12 +U 9 +D 9 +L 16 +U 10 +D 4 +R 13 +D 4 +U 6 +L 1 +U 6 +R 12 +L 6 +D 8 +U 11 +D 9 +R 16 +U 14 +L 15 +U 15 +D 5 +R 6 +D 16 +R 1 +D 10 +L 5 +R 12 +L 1 +D 9 +U 9 +D 11 +L 9 +U 5 +R 11 +U 16 +L 6 +D 13 +L 3 +D 7 +U 1 +R 11 +D 6 +R 6 +U 7 +L 14 +R 2 +L 6 +U 8 +L 9 +R 3 +D 1 +L 13 +R 8 +L 14 +U 11 +D 13 +L 12 +U 8 +L 6 +U 13 +D 8 +U 8 +D 12 +R 7 +D 16 +U 4 +D 2 +L 6 +R 7 +U 1 +L 12 +R 13 +D 16 +L 3 +D 4 +R 15 +U 5 +R 1 +D 14 +L 1 +U 4 +L 14 +U 15 +R 14 +L 14 +R 16 +U 10 +L 4 +D 6 +U 5 +L 15 +U 8 +L 9 +R 12 +U 7 +R 4 +L 16 +U 10 +R 6 +U 14 +L 3 +D 13 +L 6 +U 12 +R 3 +L 16 +R 16 +U 8 +R 13 +U 7 +D 6 +R 3 +U 16 +L 2 +D 2 +R 17 +D 17 +R 3 +L 11 +R 12 +L 1 +R 17 +L 9 +U 2 +L 16 +D 16 +L 7 +R 2 +D 13 +U 1 +D 5 +L 5 +U 14 +D 13 +R 3 +U 5 +D 9 +L 9 +U 3 +L 2 +U 8 +L 5 +R 13 +L 8 +U 2 +R 6 +D 2 +L 9 +U 15 +R 14 +U 1 +R 11 +D 13 +U 9 +D 17 +R 14 +D 14 +R 7 +D 3 +L 1 +R 15 +D 13 +U 14 +R 3 +U 5 +D 15 +L 10 +R 10 +L 1 +R 16 +D 13 +L 17 +U 9 +R 1 +L 4 +U 4 +L 3 +R 10 +L 14 +U 17 +R 6 +L 17 +D 11 +R 5 +D 5 +U 1 +L 9 +U 7 +D 1 +U 6 +L 13 +U 6 +D 13 +R 17 +U 3 +D 5 +L 15 +U 3 +L 5 +R 12 +L 16 +U 8 +R 7 +U 16 +R 14 +U 17 +R 2 +U 6 +L 5 +U 17 +D 11 +U 3 +R 8 +D 5 +U 16 +R 1 +U 11 +L 15 +R 12 +L 5 +D 13 +L 16 +R 14 +L 15 +D 17 +L 6 +U 9 +R 18 +D 8 +U 6 +L 18 +U 11 +L 3 +U 18 +D 14 +L 17 +D 5 +L 15 +D 5 +L 12 +D 13 +U 9 +L 7 +R 11 +U 12 +L 4 +R 6 +U 7 +D 17 +U 13 +L 10 +U 15 +R 7 +L 2 +R 8 +L 7 +U 1 +R 17 +L 17 +D 4 +L 13 +R 2 +D 5 +U 3 +L 1 +U 2 +D 18 +L 3 +D 17 +R 6 +U 12 +D 11 +L 1 +R 10 +U 9 +D 7 +R 12 +U 11 +D 13 +L 11 +R 14 +U 6 +R 11 +L 13 +U 5 +D 15 +R 12 +U 10 +R 16 +D 16 +L 1 +U 18 +R 8 +L 8 +R 4 +L 18 +U 5 +R 15 +L 15 +U 13 +D 16 +R 4 +D 13 +R 6 +L 13 +D 1 +U 8 +R 13 +D 8 +L 17 +U 12 +R 2 +U 13 +L 6 +U 16 +L 15 +R 17 +D 1 +R 8 +D 9 +R 4 +U 11 +D 11 +L 12 +R 10 +U 2 +R 3 +D 7 +L 2 +U 8 +R 3 +D 4 +U 6 +L 8 +U 9 +R 7 +D 1 +U 12 +L 4 +U 13 +L 11 +D 14 +U 18 +L 17 +R 4 +L 19 +R 1 +D 12 +U 9 +R 11 +D 4 +U 15 +R 7 +D 6 +L 17 +D 4 +R 5 +U 11 +R 9 +L 4 +U 11 +R 10 +U 4 +D 19 +U 18 +D 12 +R 2 +L 15 +D 1 +R 13 +D 3 +R 5 +D 6 +U 11 +L 3 +D 5 +R 2 +D 15 +R 4 +U 19 +D 8 +L 11 +R 17 +U 7 +D 1 +U 2 +R 18 +L 10 +R 4 +D 7 +U 8 +L 1 +U 11 +L 15 +R 2 +U 13 +R 12 +L 8 +R 1 +U 4 +L 12 +R 13 +D 7 +U 5 +R 14 +U 13 +D 13 +L 18 +U 18 +R 14 +D 18 +U 12 +D 11 +U 6 +R 6 +U 5 +R 4 +D 7 +R 1 +U 5 +R 1 +D 1 +U 13 +D 10 +R 19 +D 7 +U 14 +D 7 +U 19 +R 12 +L 2 +D 12 +U 10 +D 17 +L 12 +U 1 +R 8 +L 8 +D 15 +R 9 +U 5 +R 11 +L 10 +R 2 +L 13 +U 10 +L 7 +U 1 diff --git a/src/cli/commands/day004.rs b/src/cli/commands/day004.rs index 8f1a4c9..7d7129c 100644 --- a/src/cli/commands/day004.rs +++ b/src/cli/commands/day004.rs @@ -1,8 +1,55 @@ -use crate::cli::PathBuf; use crate::util::read_lines; +use std::fs::File; +use std::io::{BufReader, Lines}; +use std::path::PathBuf; + +fn part1(lines: Lines>) { + let mut full_containt: u32 = 0; + let mut overlapping: u32 = 0; + for line in lines { + let temp_line = line; + let mut team: Vec = Vec::new(); + temp_line + .unwrap() + .split(",") + .collect::>() + .iter() + .for_each(|s| { + s.split("-") + .into_iter() + .for_each(|s| team.push(s.parse::().unwrap())) + }); + let t1_start: &u32 = team.get(0).unwrap(); + let t1_end: &u32 = team.get(1).unwrap(); + let t2_start: &u32 = team.get(2).unwrap(); + let t2_end: &u32 = team.get(3).unwrap(); + if (t1_start >= t2_start && t1_end <= t2_end) + || (t2_start >= t1_start && t2_end <= t1_end) + || (t1_start == t2_end &&t2_start == t2_end) + || (t1_end == t2_end && t2_start == t2_end) + { + println!( + "Gruppe full: {:?}-{:?}, {:?}-{:?}", + t1_start, t1_end, t2_start, t2_end + ); + //println!("{:?}", team); + full_containt += 1; + } else if (t1_start < t2_end && t1_end < t2_end) || (t2_start >= t1_start) { + println!( + "Gruppe part: {:?}-{:?}, {:?}-{:?}", + t1_start, t1_end, t2_start, t2_end + ); + overlapping += 1; + } + } + + println!("full {:?}", full_containt); + println!("part {:?}", overlapping); + println!("total {:?}", full_containt + overlapping); +} pub fn subcmd_day004(file: &Option, alt: &bool) { if let Ok(lines) = read_lines(file.as_ref().unwrap().as_path()) { - + part1(lines); } } diff --git a/src/cli/commands/day007.rs b/src/cli/commands/day007.rs index d3a26ec..c39e4a5 100644 --- a/src/cli/commands/day007.rs +++ b/src/cli/commands/day007.rs @@ -1,14 +1,99 @@ -use std::path::PathBuf; -use std::fs::File; -use std::io::{BufReader,Lines}; use crate::util::read_lines; +use std::cell::{Ref, RefCell}; +use std::fs::File; +use std::io::{BufReader, Lines}; +use std::path::PathBuf; +use std::rc::{Rc, Weak}; + +#[derive(Debug)] +enum FsNodeType { + File, + Directory, +} + +#[derive(Debug)] +struct FsNode { + vname: String, + vsize: u64, + vtype: FsNodeType, + parent: RefCell>, + childs: RefCell>>, +} + +impl FsNode { + fn new() -> Rc { + Rc::new(FsNode { + vname: String::new(), + vsize: (0), + vtype: (FsNodeType::File), + parent: RefCell::new(Weak::new()), + childs: (RefCell::new(Vec::new())), + }) + } + + fn new_file(fname: &str, size: u64) -> Rc { + Rc::new(FsNode { + vname: (fname.to_string()), + vsize: (size), + vtype: (FsNodeType::File), + parent: RefCell::new(Weak::new()), + childs: (RefCell::new(Vec::new())), + }) + } + + fn new_dir(fname: &str) -> Rc { + Rc::new(FsNode { + vname: (fname.to_string()), + vsize: (0), + vtype: (FsNodeType::Directory), + parent: RefCell::new(Weak::new()), + childs: (RefCell::new(Vec::new())), + }) + } + + fn set_parent(&self, new_parent: &Rc) { + *self.parent.borrow_mut() = Rc::downgrade(new_parent); + } + + fn add_child_node(&self, cf: Rc) { + match self.vtype { + FsNodeType::File => {} + FsNodeType::Directory => self.childs.borrow_mut().push(cf), + } + } + + fn get_size(&self) ->u64{ + self.vsize + } + + fn get_size_of_tree(&self) -> u64{ + let mut csize:u64 = self.vsize; + for c in self.childs.borrow().iter(){ + csize += c.get_size_of_tree(); + } + csize + } + + fn get_parent(&self) -> Option> { + self.parent.borrow().upgrade() + } + + fn get_child(&self) -> Ref>> { + self.childs.borrow() + } +} fn part1(lines: Lines>) { - + let tnode1: Rc = FsNode::new_dir("test"); + let tnode2: Rc = FsNode::new_file("test", 10); + tnode2.set_parent(&tnode1); + tnode1.add_child_node(tnode2); + tnode1.add_child_node(FsNode::new_file("tesd234", 55)); + println!("{:?}", tnode1.get_size_of_tree()) } pub fn subcmd_day007(file: &Option, alt: &bool) { if let Ok(lines) = read_lines(file.as_ref().unwrap().as_path()) { - + part1(lines); } } diff --git a/src/cli/commands/mod.rs b/src/cli/commands/mod.rs index 15d7614..fb4a73e 100644 --- a/src/cli/commands/mod.rs +++ b/src/cli/commands/mod.rs @@ -7,19 +7,19 @@ pub mod day006; pub mod day007; pub mod day008; pub mod day009; -pub mod day010; -pub mod day011; -pub mod day012; -pub mod day013; -pub mod day014; -pub mod day015; -pub mod day016; -pub mod day017; -pub mod day018; -pub mod day019; -pub mod day020; -pub mod day021; -pub mod day022; -pub mod day023; -pub mod day024; -pub mod day025; \ No newline at end of file +//pub mod day010; +//pub mod day011; +//pub mod day012; +//pub mod day013; +//pub mod day014; +//pub mod day015; +//pub mod day016; +//pub mod day017; +//pub mod day018; +//pub mod day019; +//pub mod day020; +//pub mod day021; +//pub mod day022; +//pub mod day023; +//pub mod day024; +//pub mod day025; \ No newline at end of file