Initial commit: Days 1 - 5
This commit is contained in:
12
Makefile
Normal file
12
Makefile
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
SQL_FILES := $(wildcard *.sql)
|
||||||
|
|
||||||
|
latest:
|
||||||
|
@FILE=$$(ls -1 *.sql | sort | tail -n 1); \
|
||||||
|
duckdb -f "$$FILE"
|
||||||
|
|
||||||
|
run:
|
||||||
|
@for f in $(SQL_FILES); do duckdb -f $$f; done
|
||||||
|
|
||||||
|
format:
|
||||||
|
@for f in $(SQL_FILES); do sqlfluff format $$f --dialect duckdb; done
|
||||||
|
|
||||||
4503
data/01.in
Normal file
4503
data/01.in
Normal file
File diff suppressed because it is too large
Load Diff
1
data/02.in
Normal file
1
data/02.in
Normal file
@@ -0,0 +1 @@
|
|||||||
|
9100-11052,895949-1034027,4408053-4520964,530773-628469,4677-6133,2204535-2244247,55-75,77-96,6855-8537,55102372-55256189,282-399,228723-269241,5874512-6044824,288158-371813,719-924,1-13,496-645,8989806846-8989985017,39376-48796,1581-1964,699387-735189,85832568-85919290,6758902779-6759025318,198-254,1357490-1400527,93895907-94024162,21-34,81399-109054,110780-153182,1452135-1601808,422024-470134,374195-402045,58702-79922,1002-1437,742477-817193,879818128-879948512,407-480,168586-222531,116-152,35-54
|
||||||
200
data/03.in
Normal file
200
data/03.in
Normal file
@@ -0,0 +1,200 @@
|
|||||||
|
2353224242223333222212222212122232212325242222323234222233222242242213332433221534222221224132232122
|
||||||
|
2238627227623421225352362446932882413382783432342232284228276225212222465623527237113223452255221122
|
||||||
|
4333584553665256334444432629376353732486456562233346544226565255522533335442345422534625531566554453
|
||||||
|
2331515514151522535351533453445225411445433534454355153332542341241432153554213241545122535524336789
|
||||||
|
5244553233324443423132423535451232232222244255155243543225522452223243441551222523239452525132222275
|
||||||
|
6467467676645453567374642755656377365716546987664947684645954566548644568644547565868635656632655577
|
||||||
|
3299363734434823696343285343334412335442473823345434344433744533134432329449246232233214378444363733
|
||||||
|
3233481436375215413242453252833233373534332321335225254235255339133623235563231244322322333352332332
|
||||||
|
2522162223212222122221122323322421422312221922212224237272222122322229322112222212222232212526222222
|
||||||
|
4234334414524442463434433444442445436442442432346334543343324333344434444344544445134443442232354433
|
||||||
|
3643443543334343444242443425223333353334723236434334457454353537334235534344442433246444324143433423
|
||||||
|
2212429383247323851422241442624237362222628243346233222464222363966437445347434372434434212223437682
|
||||||
|
6465366332534263763231523241522341332871336132244226422122742536537624251632522124713322622632233332
|
||||||
|
2224422232242212251325212222225221223222824142211222222122322216222332122423433242142132212224222232
|
||||||
|
4344434366338353665448569343557745435533834635377445156855347885357545545466595484953545456439336636
|
||||||
|
2232222229272422232122221412111221219243227212222222221113221223222122232322233222222321232122121322
|
||||||
|
2222342242222122222222322124621332222232311221422222312211222221267421322232221223222233332111212223
|
||||||
|
8645545447936673855846524747618565545426273436355834628447553134327265347425343334723133444453344248
|
||||||
|
6185554735288258267542829442735385499736515228542596435823643473264344338722259228849217876874425372
|
||||||
|
5523882142244292214453529242344647323823751563443322495344447423625762272535562253443443736432417763
|
||||||
|
2153434244844424544434235443539344343444432244552455443342443454533345344322444543435434434932434343
|
||||||
|
2422322524141221232233221364223233323622532236222423232242332341333252338233573113223232122213332339
|
||||||
|
3234233251242122132225212222222264222232132223224331412421121222312322212533312122422442124323122122
|
||||||
|
2122222212342112222222322222312223132322232212222321322932233122222222223222222133132322233314112223
|
||||||
|
5583554436335463352356253345554853743186232339535558342437646234554334555543534634446625544658153632
|
||||||
|
3221157534221432932228122336523332232232336342322232132633231223331345222622243225623321222623344271
|
||||||
|
1222137211326322142532422252222186525322137123342221212612117221223252123571222225422621214243275812
|
||||||
|
3262322253212424382224332134243422462322221143225232112142112222341223251132553231132243122262221552
|
||||||
|
5322222622223363221323232232622421322262232221432325122223332222323214224632122123232123232122542232
|
||||||
|
2224221133212222253321212221122221221222322293322321321212223222422221322131122122132212132132222323
|
||||||
|
8774396444632332222241452334444333363335437437334333525324563633447643233347353447497324352373234333
|
||||||
|
8611862331864212455238316728512838438257686862254542422568868465624813586343131411538485543542242219
|
||||||
|
7686757556483568757566678855786767557595167745569555776555956647877671863782577567539678336876845557
|
||||||
|
7744488628556678972964355645896755764635555747374775634473657444467564772547476787475655865553937676
|
||||||
|
6662432182732552125326635535425454552336243735493226323391723374435754314233359342367744133553942244
|
||||||
|
5333224125221632323228432332322343332324574242223253242223232538323222327433222133324363333332243435
|
||||||
|
4662328122223322223222272522214622933221212242213126723224623214252267222382224724422127764722387151
|
||||||
|
4434476337343426474454454543473444332724454444457364643954834243515337452442436534134324264444346437
|
||||||
|
5447367434345444525643554224743443743544523534267653547452453745322654444433457354644534214233454454
|
||||||
|
1378494256266946932588715479827669389979688127855958274449792247329455687859795879377579497795295166
|
||||||
|
3342345334334433152214433234334434243431435424543544343454454542344533455551233443444844352342936535
|
||||||
|
4425462424453442464545454452534333242544453313255333434324574262336434844727454314435634343315864444
|
||||||
|
6345157454242645227413742425365354664557775633555443246367415435532927644524346863346465332543425324
|
||||||
|
7222225222212225522311245333222272232132216225244222114322222272122152393123242222242313422224232242
|
||||||
|
2135125333124222223122533333433364332233334213223233126222123223323213323333333614233825333332224233
|
||||||
|
2922423512236225112823232222322112485144333223262222172226212722224222221222422282322222725222622612
|
||||||
|
2913332343253429423423234323323331434333333343423323333342332236332235343343234331315333332333143332
|
||||||
|
2462122122732424222512322235322222223112716233172221533114316273421724262222326212212132223341251222
|
||||||
|
5443434462941334334862437483744722496644846368384529744975644964735244343425876544334456524129258554
|
||||||
|
2323262314323522643342432224522342214243421525313244151526727115455324252242522225223242352125335522
|
||||||
|
5224534332232443343433423434443443332242443425452234243441331323342234243333341312432384222421143214
|
||||||
|
4523224266852222252722822322324442335112222882215826228232222534263624221441222412726235224536222123
|
||||||
|
4252433335454333433433122322132613523242334213236326325227234422326423133527223432333333333232233322
|
||||||
|
2824678323727226712832912263144865192522142434756275362284994422511242527821279234264486861435255459
|
||||||
|
1342254544224131632222251253275232162636613256433221332222232322922322661164224322512422424234222223
|
||||||
|
3332363333313242651134753333233433343443334336633234352333329353522143334333973515323333832376354333
|
||||||
|
7232364331352614221373624273332531224483532523263442462222232242233332353335952253333365312342226533
|
||||||
|
2242223345212524325312342249233124322443412252524322542534322443228342135432535282232221588223433232
|
||||||
|
6443649223332263872223533333273545325252842695648521343475343433177336335223435342832444322223412437
|
||||||
|
3766574737237225244271352675413356271626667755577143246157515371641345111157374174373664123325356589
|
||||||
|
2223121222122527212121331222422222222242272226223342253223762223333138222262233224411222232321226112
|
||||||
|
4277726633445261334632354844537614726225544441413647633125836374249884224443788668658543565427244385
|
||||||
|
6445422592225431525522123526443452233435444443244422233742452214243454223341316382142344242365163124
|
||||||
|
1143453323233533224433232315621252454332344141543144333312332552363753422337453242534522233273422323
|
||||||
|
3723221422324433422243233242122113233212322333634314223523134234255232222535135242142261223212312223
|
||||||
|
5363333327323313214763324438575542517724334124427711733121343232121336332632817232223338237331321272
|
||||||
|
1221232222232214222342222223242225223263422142342312222222124423652213522232227243222431221221222232
|
||||||
|
2332234232222232321423433622223341512122221332623312122221222233212232221193132333322213522383522222
|
||||||
|
2523223312222223324222122222211323634221232223232222262212132233222212122292122212231122222122221222
|
||||||
|
3313436445333333542373333333366433332433433334323339342363531313322343383535333353334133434439333343
|
||||||
|
2222124253723233223213317221933232424212322211232325325332232232334252332242222326123323322232322322
|
||||||
|
7338624725437336277315442535224236542964554734276858544623435123734226342242546253253445347764256233
|
||||||
|
3452195946122722232242232432253623334116442924221881432244338324335222122931422532473232333734483162
|
||||||
|
4654343244544644325423324545344434653421133244345322443232453434424335323636323443442133432544433445
|
||||||
|
2411324322222552532222822121224423223222212221122221225242122132222212333221222222217243232221222222
|
||||||
|
5465673345856346652586576646249781478254229778535294514846277852225274963847477866675475667467565777
|
||||||
|
4374353711437236534446233537475727574355344663654232546472344388535337445247337237435253353233543332
|
||||||
|
7732745395362367433555647772547773333245537376374673363366634366474657674885763735657736343547663635
|
||||||
|
2516235143651122522513142111644454255244664622364135655666323525143323546344333442535254452643655789
|
||||||
|
7734235122322443636834272155462353744333358223233783563475464545333243548327582656733725767824622488
|
||||||
|
4334333343343242333522445462424454432342532734123443433342344423423432473421333543343342434451433343
|
||||||
|
2432242232252224242521122222222242443222312341122223221222223213122222421142122323225223222212132121
|
||||||
|
7523655356223928283485625887526628376363471724545654326468252473574464586483543465249256825412275276
|
||||||
|
4324223242123222122422321433212112131222323125421132212212322322231222222222414122223132222212232624
|
||||||
|
1522232531112253212123652213212432221244322121233132334223183211232222223132321512241226325221213112
|
||||||
|
1675565816346362353246545757545265765694657445667565685567555585647565345593755547455325454867364555
|
||||||
|
2313232222226222221222233222322162222322223222363222212224122423123122242233142243222222123232321922
|
||||||
|
2623333322126318342122442332914223341223432213372323224932234332232222423334212142545335323273321412
|
||||||
|
3447469713328311462242297772822667722625342545423233829632467279456123478431625377426273449922225232
|
||||||
|
2431212624125236322238421352512591724552222221223725262455222521362233126764162522522315232622422422
|
||||||
|
3323232243343421134233432293323231433332322315423131412221332336654221232324433643444125312352132232
|
||||||
|
6467974665768691766464768767786659656769695666567765646775774575686257944566775286587785665674685797
|
||||||
|
1334532223332213342222335223321323291122133333423323311233223222232232323332232221365532242223312233
|
||||||
|
8673523332221221737338334233242312312333636443223432275222232536311543222221542464314213332328353242
|
||||||
|
2763422247622232714212126372224423525374525145241427724133242223222522532434245243224733334246223233
|
||||||
|
3396312222537221284525221332356421513224523322143342626222522215243122212254432828232352522243252181
|
||||||
|
4335434424276163434442364543353483874463226534823335432532943445424133445226364411332453463711253764
|
||||||
|
2633313224535333534344643424334624344342314434823142772334334333734324352439413414235422334333364233
|
||||||
|
6564332641251125462424666122542144323253354253236317931272566133456226545134626454555351364572313548
|
||||||
|
2254422444265545453542442533326342132444243455243242534445157354562444652332333425352424252534345232
|
||||||
|
2312223332222223113222122422432141452231332313212343222223222222412242324334222234222223122222412252
|
||||||
|
6527226656123754212251268446348566541122243453176634522222722172272233572252221264472245221262225213
|
||||||
|
3212242433223242123233432311224233133143372432233212332912123334222332323311334228422323234332214242
|
||||||
|
3234235367223475472153252333331523222243333472433235233229225637523512221333436274533436211442222433
|
||||||
|
7736657756564666554584449756545747769676456655145666365566715735276623565585996572666464945676466646
|
||||||
|
4333452223335433433334233243324222342283324223421433334244232344157333335233328453233343472312422349
|
||||||
|
2272153272234523222365371352222862213672212346132823526235241153676737744625761414822375424275765523
|
||||||
|
4223134244634237132243344221214321432443932735222133523132451245123422431264222252216372222195262532
|
||||||
|
7635333657347543326863443434347783833336936542433337456346336332683563668575432162334443524473884545
|
||||||
|
4623243422196562443629656975223262634432742336181737221575322855237433672385356537623268634753131443
|
||||||
|
2422222242343212242422443234141141232212212228643123224352234421131222222324263323122432222244863322
|
||||||
|
6477525433221758477419625546469714335354763813463326664713654622251333622538373222465435339932582366
|
||||||
|
1875222142133538953133232322522244231945222222663825122874273282336583321452343467131212755726126222
|
||||||
|
4434645465533447264345643324352324524661423137354144322363434514343541633554633433933487233325134524
|
||||||
|
3223333534335324333233253221326352746323155212334323393334373333529335322252243262252632252332352333
|
||||||
|
4321222333222223323222251322322322222432241232213222322213132234542412232212431322223233222221312621
|
||||||
|
3231134434231233312132123323144232313142433222212243233214334343311422314333141211231134111123356789
|
||||||
|
2642423425364131113245452542456223623443242231223352624413324343722232735416432622553424224422435343
|
||||||
|
2321233661223452233213222424322211242232412222381222328312252352251425294212332322222232712222121322
|
||||||
|
2225222234222221224421435522243354253234342241222212111113221234442222474332244322224423123212122222
|
||||||
|
4224422122333123213242223234234423223234212322423332134322333232331334322222224142354422223341322213
|
||||||
|
2237352222224332223522322342333322236529322272222332112232322221321123332332262122222231213222232222
|
||||||
|
2222333213332333323243333434232332212322233333342122333133143333334322332342323232331532233333324333
|
||||||
|
5834325323443344444444454964423434334339295245744244343343344334348213543434343343541425544453344624
|
||||||
|
1225233231222422233124212342111222313222221323231232124324432233232222324412233113122222323322214522
|
||||||
|
2377467568477534475657417583649454125369574763549753369556325655544737495557848684585453544956255773
|
||||||
|
5458433696666543525525556435575442756285545558725545535535944455334455534564755655555365445635435535
|
||||||
|
9847555865827676657688569759758758555445794968796565767687569857578579948785658658585576858447769967
|
||||||
|
6613238261823242523545581723261232235645224814221675642212653642225426832322543652227122633712124122
|
||||||
|
4223136832152221221242224242421235231312422222372653842432251222217222233221128457252413232723312132
|
||||||
|
6523524422321452322662663213432423223625223656261423272235914253154355243241223362223223223156453323
|
||||||
|
3332426321425322751232142373324233674432334367314443332124347171245364341232233447344325331253477224
|
||||||
|
3424223224249422222252522222322621432123226234321437344236662432624643662352454234623382552222223522
|
||||||
|
4745777547674765475775774656648825546857634574258748465853668592564853254582492758724654777546552643
|
||||||
|
6874766656665463175556445556564555646566545766644754544565666652655555657356465666844665542644366655
|
||||||
|
3323233323323522173224232322323233224223112213213232333221322243313233233122232352237332333323322333
|
||||||
|
2332332231212212323323222333233223223222263231212226232231212212222232323323634323231333342333111232
|
||||||
|
2384433334231232533333242135333543234433233252432333332323336631332314333333233243322223452522133313
|
||||||
|
3213252233232232332231331532642243333323242222323224113332254244242513324322214215313252343221222323
|
||||||
|
3333442443343433323423335143432332423443324323313532232434333342344333344232243532313423433332233233
|
||||||
|
2442444321442243128341345434255155444374435164232224644444124414243424432534483222232334323244333443
|
||||||
|
3313442141242234344233241342333224232341144322333152433342322332314552226223322352333235232932154434
|
||||||
|
4441424342443643444352244423125443442234423624444463144342342342124434234423345623144613632462344543
|
||||||
|
7566246755377854878728979949865656386773879557878689867467898977779735578737985559795598997657876456
|
||||||
|
2433325321441321222262222333452424322222212433521232533322322323322312212333222234212221212323342222
|
||||||
|
8863468696899235884458428968738919231387528869689126392827879217994372382772927392449629876546839273
|
||||||
|
2225734443314333633234333323321324542243243544742333523323433334434133463331334426443542431343264342
|
||||||
|
6555535456552536485353733334546644451556565452546454416757523955445347246464464535444443425334565253
|
||||||
|
4224543525334235224219142146114222324331221341524242222211243552222222581244332321232276354744252222
|
||||||
|
4234455344444744253534644332356446542234144444444432443444344244473435285343451443544353378444244345
|
||||||
|
1333343693255233385246362233338931243229349233139273433226237473644272523443634532943537331534373431
|
||||||
|
4244236433332433333322333333223343233332242233344333234433333333334534323533333334313233334353323323
|
||||||
|
5423256123322325222235232523112323437324414335321323226333233462352282522122522232132522322334524631
|
||||||
|
3822342336645552493494648368266599555342696296653264344868567685454684553668526834564633355945447866
|
||||||
|
2213312223222233332243232324364231333432312432423423352592433352223424325322432322935354222229343235
|
||||||
|
3222362713644432612232553232254225244424237526131222653222333152522226612426222655122221126242126262
|
||||||
|
3433335333343333533339359253131931343323223613335413343233213533333373337333413331383333254333533324
|
||||||
|
4238131312372266238322323992851888128123122242282434742712328963325226342472212242762454422754113423
|
||||||
|
2533763527162452233223312322522222222463252222221537324452124222233212423117175312232562225312223132
|
||||||
|
4355252364454352653444344352434454444365563345544335455442244324555345645453344434544262654443354444
|
||||||
|
3222333333331223223342537223533233224234342325233322432234424133131223333354422332223322134343324234
|
||||||
|
3235313334434935233364333358422336345244423533352323334733321434232423533223343423245143335433313355
|
||||||
|
7697963986575952869578568946977734786777764174559666468678697847993886557885687487698767835597768965
|
||||||
|
5222132412221423232223233342232224221242224325132323122223332642342122233122223422331144322125222432
|
||||||
|
3433233333316233323332333331333433333311223433223332332333132343433233313433323142243223333452342233
|
||||||
|
3224122132332334432842432444234444143344452322333363442433433442333444441342323323443242433523233446
|
||||||
|
3114233442225222434322233125352433227221132313121349242332232334223333231122335313224222233142243211
|
||||||
|
2222221322122111132232222222222222221221232312322212223132232221222222311222212212222122133132221222
|
||||||
|
6232242212224272122326144421411264222312221232433517214143332124722422223322224622472272323224228424
|
||||||
|
3222232132223232332222322222242321133722212322223313322331231332222332322233122232122222233232221342
|
||||||
|
2221223332211613521221222222166122222222122322222432182122512232225224121362222225221352222426222422
|
||||||
|
1212221622212224222722822222231222231722253222333222322223242221322226222362222322324222524221142243
|
||||||
|
2243232122244322321423443121112223332223334322123142336247321341222222221323432233212322431323323242
|
||||||
|
2477541421421212523544524234435357333455343445773315222547448321533765635533351446547455454532354315
|
||||||
|
6455365435366156655234455243423435533613423132633454254236643252253477591444435334313234333452215654
|
||||||
|
7846638476554768752458675595477943359658686473796148755347335676585536664843746345466357726596263563
|
||||||
|
1475423222553125435222445752252422332255232122244332221612453259315242432242223252222533564433221525
|
||||||
|
5564544453445544243435454843336734855563554272347436435235443545533333443444554754434433446444526445
|
||||||
|
1131212222222223212222222432412221423232233131552221642112223232227411122227321256722131132142122934
|
||||||
|
3427662365266236258757354314556462242745682674515375567224366445522522246357735414163132668565436257
|
||||||
|
3222423333532334552532453223355353427322453214333513642242312352327675244324512632525363366333556753
|
||||||
|
2313232123243245232222422333322223522342222432223642258522323124222233222422333322233222442323232322
|
||||||
|
3557826334243455753445448244454748554235356374552378431535423443334335333413455754454555428335353533
|
||||||
|
4222725565222545153214372421122136354112352223535122153132522232222221423213222222123321232222325242
|
||||||
|
3337324234323263423244332343433333434432242273343331833356333221433473435332553423443533143445433343
|
||||||
|
4345454523343352443337322333333323334362521663554323433344351237852333328247845444331113433392233327
|
||||||
|
2232123183322215223322251225162354112223535221252253222222232221232222223422223322322242122232322222
|
||||||
|
2223223212123222224322322223423222332324124133236222132322232212123131231221136333342422332222332222
|
||||||
|
1421232213322322232223131322212131231223221311313333133222232333132334323213133232232212331332222112
|
||||||
|
1322123232232243423313212215222123212242721222322317144252262472233213212322212422222313223243421222
|
||||||
|
2223222122222222223222135221322212224225252432522112214282221515122227332123211222332314211215252222
|
||||||
|
3534147622334554582542466524142269162252326432543244929242322286827523224522677326258211373392773568
|
||||||
|
2232121322231323234123222222231222515222222122121122222322325132222223222422232222132232222233232232
|
||||||
|
2213251232233123222211233223323133222132222532313211122122232222232144221325111112222134423662212232
|
||||||
|
4545444353275454654344545244455543455555475154354662444445544644525564544244445455523154244545744444
|
||||||
|
5774546566885687435555886759544756677558484755987675674636444879566765585496675474346575544644485499
|
||||||
|
4275534464214754656464644825342342223257727338545457335353557353264475446332935672653437554246675445
|
||||||
|
5222333352562523222112363624222421626421144642526322298233124462243752353641723432321232422224511363
|
||||||
|
2222544122212134422245322622323232121113423222422311232232422322223221212233652414122759322232231122
|
||||||
|
2342222332222272222432421224223245222124221224321242411222237231231217442234312223223122222112227422
|
||||||
137
data/04.in
Normal file
137
data/04.in
Normal file
@@ -0,0 +1,137 @@
|
|||||||
|
@@@.@..@@.@@..@.@@@...@...@@@.@@..@..@@@@@@.@@.@@@.@@@@@@@@@@@@@......@@@@@@@@......@@.@@@@@@@.@.@@.@@@@@.@...@......@@@@@@@@@@@@.@@@@@@@
|
||||||
|
@@@.@@@@@@@@.@@@@.@@@@.@.@.@.@@@..@..@@@@...@@@@@@@@.@@@.@@@@@@.@..@@@@@.@@.@.@.@@@@.@@@......@@@@@.@..@@@...@@@@@@@@@@.@.@@@@@@@@.@@@@..
|
||||||
|
..@@@@.@.@.@@@.@@@@@..@@@@.@@@@..@@@.@.@@@...@@@@@..@@@@.@@@@@..@@@@@...@@..@.@@@@.@@.@@.@@.@@.@..@.@@@@@....@@@...@@.@.@@@@@.@.....@@.@@
|
||||||
|
.@@@..@@.@.@@.@@@@@@..@@@.@@..@@@@...@@@.@@@.@@.@@@@@@.@@@@..@@@@@.@@@@@@@..@@....@@.@....@@@@@.@@.@@@..@@@@.@.......@@@@...@@@@.@..@..@@
|
||||||
|
@@@..@..@@@@.@.@@@@@@..@@@@..@.@.@@@.@..@@@@@.@...@..@..@...@....@@..@@@...@@@@@.@.@........@..@@.@.@@...@@@@@.@@@@..@.@@@@...@..@@.@@..@
|
||||||
|
@.@@.@.@..@@@@.@.@@@...@@@..@.@.@@..@.@@@......@..@...@.@@.@@@.@@@.@@@@..@@.@.@@@@.@..@..@.@@..@@@@.@@@@@@@@@@@@..@@@@..@@.@.@@..@@..@..@
|
||||||
|
.@...@@......@..@@@@@...@@@@@.@@@.@@@@@.@@..@@@@@@@.@@@@@@@@@.@.@..@@@@...@@.@...@@@@@.@@@@@...@.@.@.@@.@@.@.@@.@@@@.@@@@@@@@@.@.@.@...@.
|
||||||
|
.@@@...@@@.@....@@@@@@@.@@@.@@@@.@@...@@.@@@@@@...@@@@@..@.@...@.@@..@@..@@@@@@.@@@@@@@@@@..@.@@..@..@.@@..@@.@@@@@@@@...@....@.@@@@@@@@@
|
||||||
|
.@..@@@@@@@@.@@@.@@@@@@@.@@@@@.@.@.@@@@..@..@@@..@@@.@@@@.@@.@@@@@..@@@.....@@@.@.@@@@.@@.@.@@@@.@@...@.@@@.@@@@@@@@@..@.@..@@@@@@@.@@@@@
|
||||||
|
.@.@@.@.@@@@@@@@@@@..@@@@@@....@@@.@.@.@@@.@@@@@@@@.@@@@@@@..@@..@@@..@@@...@.@@@@..@@@@..@@@@@@@@@@@@.@@.@@@@@@@@@@..@.@.@.@@.@@.@....@.
|
||||||
|
@@.@@@@@..@.@.@@@@@@..@@@.@@.@.@@..@@@@.@@..@@@@@@@@.@@@@@@@.@@@@@@@.@@@@...@@@@.@@@@@@@.@@..@@.@.@@@@@.@@@@@@@.@@@@@@@@.@.@.@.@@@@@@@@.@
|
||||||
|
..@@.@..@@.@..@.@.@.@@...@@@...@.........@@.@.@@@.@.@@.@.@@.@@@@@@@@.@.@.@@.@@.@@@@@@@@.@@..@@@@@.@@.@@@@@@.@.@.@@@.@.@.@.@@@.@@.@@...@@@
|
||||||
|
.@@.@@@..@..@@@....@@@.@@@@@@@@..@@@@..@@.@@@@@..@@.@..@@@@@@@.@@@@@.@@@@.@@@@@@@@@@@.@..@@@..@@.@.@@....@@..@@.@@...@..@@@@@@@..@.@@@@@@
|
||||||
|
.@@.@@@@@@.@@@@.@.@.@..@@@@.@..@@..@.@@@@@.@.@@@@@@@@@.@@@..@.@.@.@.@@@@@@@@@@@@...@@.@@@@@@@..@.@.@@@..@...@...@@@@.@@.@@@.@.@.@@@...@..
|
||||||
|
@@.@..@@..@@..@.@@@.@@@@.@@@@@@@..@.@@.@@@.@.@.@@@@@@.@@@.@.@@@@@@.@@.@@@.@@@@@@@@@@@@@@@.@.@@@@@@..@@@@..@@.@@.@@@@@.@.@@@@@.@@@@.@@@@@.
|
||||||
|
@@@@@.@.@@@.@@..@@.@.@@@@@.@@@..@@@@@@..@...@....@.@@..@@@@.@@@@.@..@@.@@.@@@@.@..@@.@@@@..@@@@.@.@@..@@@@.@.@.@.@@@.@@@@@@.@@@@.@...@@@@
|
||||||
|
@@.@@@..@..@.@.@@@@@@@@@@@....@@@@@@@.@.@@@....@@.@@@@@@@@@@..@@.@@.@.@.@..@@.@.@.@...@@.@.@@@@.@@@@@@@@@@@...@.@..@.@..@@@.@@@.@..@@@@..
|
||||||
|
.@..@@@..@@.@@.@..@@@@@@..@@@@.@@@@@@@@@@@@.@.@.@@@@@@.@@.@@@@.@@@.@..@@@@@.@@@@@.@.@.@@@@@@.@.@@.@.@.@@@@.@..@@@.@@.@@@.@@.@@@@..@...@@@
|
||||||
|
@@....@@.@.@@....@.@@.@@@@@@@@@@@@@..@.@..@@@@.@@.@.@@.@.@@..@..@@@@@@@@@@@@@@@@@@..@.@@@@@@.@..@@@@@.@.....@@@..@...@@@@..@@@@.@@.@@.@@@
|
||||||
|
.@...@@@.@@.@.@@.@@@@.@@@@....@@@@@.@@@@@@@@.@@.@@..@@@@.@@.@@@@@.@.@.@@.@.@@@@.@.@@.@@@@..@@@@@@.@@@@.@@.@@..@@@@....@@@@@@.@@.@@@@@@@.@
|
||||||
|
.@@.@@@@@@@.@@@.@@.@..@@@.@@@@@@@.@@@@..@@@@@@...@@@..@..@@@@@@@.@@@@...@@@@@..@@@@@@..@@.@@.@@.@@@@@@@@@.@@@@@.@@...@@@@@@@.@@..@.@.@@@.
|
||||||
|
@@@@@.@@.@@@.@@@@@@@@@@@@.@.@.@@@@.@@.@...@@@@@@...@@..@@@@.@@@@@@@.@.@@.@@@.@...@.@.@@.@@.@@..@@@@...@@.@@@@.@@@@@@@.@@@..@.@...@@@@@...
|
||||||
|
..@@@@@@.@.....@.@..@@.@@@.@@@@.@@@@..@..@.@@....@@@@@.@..@@..@@..@.@@.@@@..@...@@..@@.@@@@@.....@@@@@@@@@@@@..@@@@@@@..@@@.@@.@@.....@@.
|
||||||
|
@@@@@.@@.@@.@@.@@@@@@.@@.....@.@..@..@@@@@@.@@@.@@@@@@..@@..@@@.@@@@@.@@@...@..@@@...@@@@.@..@@@@@...@@..@.@@@..@.@@..@@@@.@.@.@@@...@.@@
|
||||||
|
@@@@@@@@@@@..@@@@.@@@..@@.@.@@@@@@@.@@..@..@@@....@@@@@..@.@..@@@@@@...@@..@@@@@@@@@@@.@..@..@@@....@.@@@..@@@@..@@....@.@.@@@..@.@.....@
|
||||||
|
@.@@.@....@..@@@@@@@@@@@.@........@.@@@@@@@@..@..@.@@.@.@@.@@@..@..@..@...@@@@@@@@.@..@@@...@@@@@@@@.....@@@..@@@.@@@.@@.@@..@.@@.@@@@@@.
|
||||||
|
.@@@..@@@@..@@.@.@@@..@.@@.@@@@@@@@@@.@@...@@@@@@@@@...@@..@@.@@..@@@@@.@@@@..@.@..@.@@@.@@.@@@.@@@@.@@@@@@.@@.@@@.@@..@.@@@.@.@@@@@.@@@.
|
||||||
|
@@@.@@.@@.@..@..@....@.@@@@@@@..@@.@@@..@@@@@..@@@@@...@...@@@@.@@@.@..@@@..@..@@@@@.@@.@@@@@@.@@@@@.@@@@..@..@@@.@@@@.@@...@..@.@..@@@.@
|
||||||
|
@..@.@.@@@.@@@@.@.@@@.@.@@@@..@@@@.@@...@@@....@@..@@.@@@@@@@@.@.@@@@@..@@@@@@@@...@.@.@@@.@@.@...@@@@@.@@....@@.@@@@@@....@.@.@@@@.@.@@.
|
||||||
|
@@@@@@..@@..@.@.@...@@@..@....@..@@..@@@@@@@@..@.@...@@@@@@@.@.@@.@@@.@...@@.@@@@@..@@@@@@..@@@@@.@@@.@@@@@@.@@...@@@@@.@.@.@@@@..@.@@..@
|
||||||
|
@...@@@@@@@@@@@@.@@@@@@@..@..@.@@@@@..@@@..@@...@..@@.@.@.@@@.......@@@@@....@...@@@@@@@@@@@.@.@.@.@@@@@@.@@@.@@....@@@.@....@@@@@@@@.@@.
|
||||||
|
@@.@@@.@@.@.@@@@.@.@.@@@.@.@@@@..@.@@@@@@@@@.@.@@@@.@@@..@...@@@.@.@.@.@@@@@@.@@@@@.@@@..@@@@.@.@@@@@@.@@@@@.@@..@@@@@@@@@@.@..@@@@@@@@@@
|
||||||
|
@@.@..@@@@@.@@@@.@@@@@@@@@@@@...@@@@@.@..@..@.@@@@@@@@..@.@@@@@..@.@@@@.@..@@..@@@@@@@@@@..@@@.@.@@@@@@.@@@@.@@@@@@@@@@@@@.@@@@..@@@@@@@@
|
||||||
|
.@.@@@@..@.@.@...@@@@.@..@@@@@@@@@...@@@..@.@@@..@@@@@@@@@...@@@@@@.@@@.@@.@@@@@..@@..@@....@@@@@@@@.@@@@.@@..@@@@@@.@.@@@@@.@@@@@.@@@@@.
|
||||||
|
.@@@@@@@@@..@..@@@@.@.@.@@@@.@@@...@@.....@.@.@@@@@@@@@@@@@@@@.@.@..@@.@.@@@..@@..@@@@@@@.@@.@@@.@@@@@..@@.@@@@@@@@@@@@..@@@@.@.@.@.@@@@@
|
||||||
|
@@.....@.@@@@@@.@@.@@@@@@@@@@@@.@@@@@@.@@@@@@@@...@@..@@.@@.@@@@@@@.@@@.@.@@@...@@@@@@@@.@@@@@@.@@@@.@@@@@@@@.@@..@..@..@@@....@.@@@@.@@.
|
||||||
|
@....@..@.@..@.@@@@@@.@.@.@@@@..@.@@@...@@@.@..@.@@@@...@@@@@@@.@.@.@.@@@@@@@@@@@..@.@@..@@.@@@@@@@@...@@@.@@..@.....@@@@@@@@@@..@@.@@.@@
|
||||||
|
..@@@...@.@@.@@@.@@@...@..@@@@@.@..@@.@.@@@.@@@.@@..@@@@@@@@@@@@@.@@@@@..@.@.@@@@@@..@@@@..@@@...@.@@@@....@...@@..@@@..@@@@@..@..@.@@...
|
||||||
|
.@@@@@@@@.@.@@.@@.@@@@@.@@.@........@@..@@@.@.@@..@@..@@@@.@@@@@.@@.@@@@@@@.@@@.@@@..@@....@@...@@@.@.@.@@@@@@@@.@@@...@@@@@@@@@@.@..@@..
|
||||||
|
@.@@.@.@@@@.@.@.@@@@@..@.@.@...@@@.@.@.@.@@@@@@@.@.@@.@@@.@@@@@.@@@@@@.@.@@..@@@..@.@@.@@..@.@@@@@@@@@@.@....@@@.@@@@@@@@@@@@@@@...@@@@..
|
||||||
|
@@.@@@..@.@@...@@.@@@@.@@@@@.@.@@.@@@@@@@@@...@@@@@.@@@@@@..@.@@..@@@.@.@@@..@@.....@.@@.@.@.@..@..@@@.@.@@.@@@@@@@.@.@@....@@.@@@@...@@@
|
||||||
|
@.@@.@@@@@..@@@@.@..@..@@.@.@.@...@@.........@@.@.@@@@.@@..@@.@@.@@@.@.@.@@.@@.@@..@.@@.@.@@@@@@@@@@@..@.@@@.@@.@@@@@@@.@.@@...@..@@@...@
|
||||||
|
@.@@@...@@.@@.@@@@.@@..@@@.@@.@@......@@.@@@..@@.@@..@@@@@.@.@.@@....@..@@@..@@.@@.@@@@@@@.@@@@@@@@...@@@@@@@@@@@@@@@...@...@..@@.@.@@@@@
|
||||||
|
@@@@.@@.@@@@@@@@@.@.@@....@...@@.@..@.@.....@@@.@@....@@..@@..@.@.@@@@....@.@@@@@@.@@..@@.@@@.@@@.@@@@@@@@@@@..@.@@..@.@.@@@@@@.@@@@@@.@@
|
||||||
|
...@@..@..@@@..@.@@@@@@@.@.@@@.@.@@@.@.@@@.@@.@@@@@..@@.@...@@@..@.@@@@@@@.@.@@@.@@@@@.@@@@@@@@.@@.@.@@@@@.@..@.@@@@@@@@@@.@@...@.@...@@.
|
||||||
|
.@@@@@@@@@@..@@@@.@@.@.@@@.@@.@@..@@@.@@@@@.@.@@@..@@@@@@@.@@@@@..@@@@@.@@.@@@..@@@@@.@@@.@..@..@...@.@.@.@@.@@.@@@@@@@.@@@@@.@@.@@@@..@@
|
||||||
|
@..@.@.@@..@.@@@@@.@.@@.@..@@@.@@@@..@..@@@@@..@@..@@@@..@.@@.@@.@@@@@@@@@@@@@@......@...@.@@@@.@..@.@.@@...@@@@@@@.@.@@.@@.@@@....@.@@@@
|
||||||
|
@@@@@@@@@@.@@@..@@.@@@.@@.@..@@.@@.@@@@@@...@..@.@....@.@@.@@@@@@.@@.@@@.@@.@@@@@......@@.@@..@@@.@.....@@@@@@@@.@@..@@.@.@.@@..@@.@....@
|
||||||
|
@@.@@@..@@@.@@@@@@@@@@...@@.@.@.@@.@@.@.@....@@@.@@..@....@.@@.@..@@@.@@@.@..@.@..@..@@@@@@@@@.@.@.@.@...@@@@.@.@@@.@...@@@@@@..@@...@@@@
|
||||||
|
@@@@.@@.@@@.@@@@@@@@@@@...@@.@@..@.@@@...@@.@.@.@@@@@@.@@@@..@@@@..@@..@.@.@@@@@.@.@@@@.@@@.@@@.@.@@@..@@.@@..@.@@@@@@@.@@@..@@@@.@.@@@@@
|
||||||
|
@...@@.@@@@@@.@.@@@@@@@@@@@@@@@@@@..@@..@@...@@.@.@@@@.@@.@@@@@@@.@.@.@@.@@.@..@.@@@@..@@@...@@.@.@@..@@@....@@.@..@...@.@@@.@@@@@@@...@@
|
||||||
|
@@..@..@.@.@@@@.@@@..@.@@@@@@@@.@@@.@@@.@@@.@@..@@.@@@@.@..@.@..@...@@.@@@@...@@@@@..@@@..@...@.@@.@@@.@.@@@.@.@....@..@.@@@@@@@@.@@.@@@@
|
||||||
|
@@@@@@..@@@....@@.@.@...@@@@@.@..@@@@@@..@...@@.@@@@@@.@.@@.@@@@.@.@.@@@@@@.@.@@@@@@@@.@...@@@@@@.@.....@@...@@...@@@@@@@.@@@@@@@@.@.@@..
|
||||||
|
@@@@@@@@...@@@@..@..@..@@@..@@.@@@@@@.@@@..@@@@.@@.@..@..@.@@.....@.@@..@@@....@@@@@@.@@@@@@@@@@@@..@.@@@@@@@@....@.@@@.@@@@@@@@@@@..@.@.
|
||||||
|
@@@@@.@..@.@@.@@@@..@.....@.@@@.@.@.@@@.@@@@@..@@.@@@@@@..@@.@.@@@...@@.@.@@..@.@.@@..@.@.@@@@@.@@..@..@@@...@@@.@@@@@@@@@...@@@.@@..@@@@
|
||||||
|
..@@...@@@@@@@@@@.@.@.@..@@.@@@@@@@@....@@@.@..@@@@.@@@@@.@.@@@.@@.@@.@@@@@@@@@..@@.@@@@@@.@@@@@@@..@@@...@@.@@@@@@@@.@.@@@@@@.@@@@......
|
||||||
|
@@...@...@@@.@..@@@.@@@@@@@@@@@@@..@.@@.@@@@@@@@@@.@@.@@.@@.@@@@.@.@@..@@@@.@@.@@.@...@.@......@@.@..@.@@@@@@.@@@@@@....@.@....@..@@@@..@
|
||||||
|
@.@@@@@@@@@.@.@@@@@@@@@@@@..@.@@@@.@@.@@.@.@@@...@@@.@@@.@@@@..@@@@@@@@..@@.@@..@.@@.@@@.@.@@@@.@@@.@@@@@@.@@.@@.@@@...@@@@@@.@@@@.@@@.@.
|
||||||
|
@@@.@@@@@..@@@@@@.@.@@@@.@@...@@@@@.@@@@.@.@.@.@@.@..@@..@@@@@@...@@@@.@..@@@..@@.@@@.@@@@@@@@.@@@@@@.@@.@.@@@@@@@@@@@.@.@@..@@@@.@.@.@..
|
||||||
|
...@@@..@..@@..@@@@@@@..@@.@@@...@@.@@@@@@.@@@@@..@@@.@@@@@@@@@.@@@@@@.@.@.@@@@@..@@@@@@.@@.@@@@.@.@@@@@@@@..@@@@@@.@.@.@@.@...@@@@@...@.
|
||||||
|
.@@@....@.@.@.@@@@.@@@@@@@.@@@@.@.@@@@@@.@@@@.@@@@..@@..@..@@.@...@@@@@.@@@@@@@@.@@@@@@.@@@@@.@@@@@@@..@.@@@@@..@.@@@@.@@@@..@@@@@.@.@.@.
|
||||||
|
..@..@.@..@@@@@.@..@.@.@@@@@.@@@@..@.@@@@@...@.@@.@@@@.@@@@.@.@@..@..@....@@.@.@@..@.@@@@.@.@@.@....@.@@.@@..@..@@..@@@@@@@.@@.@.@@@@....
|
||||||
|
@..@.@...@@.@@@@.@@..@@.@@..@@.@@@@@@@.@@@@@@@.@...@..@@@@..@@@@.@...@..@@@@.@.@@@@.@.@...@.@.....@.@@.@@@@.@@.@@@@@@@@@@.@..@@@.@.@@@@..
|
||||||
|
@@@@.@@@@..@.@...@@@@.@.@@.@.@..@.@@@@@.@@.@@@.@@.@@....@.@@@@...@@@..@@@..@@@@@@@@@@@@.@@@..@@@@.@@@@@@@@.@.@@@.@..@@.@.@@@.@@@@..@@.@@@
|
||||||
|
...@.@.@.@@@@@@@@.@@@@@@.@@.@@.@.@...@...@@@@@..@.@@@...@@@.@@@@@.@@@@@@@@@@@.@..@@@..@@.@@@@@@@@...@@@.@@..@@@@.@@@@.@@..@@@@@.@@@@@@..@
|
||||||
|
@@..@@@@.@..@.@.@@@....@@.@@@@..@...@...@.@@..@@....@@.@@@@.@@@..@...@@@.@@@.@@.@..@@@..@..@@@@@@..@@.@@@@@@@@@@@.@@.@@@@@...@@@@.@@.@@@.
|
||||||
|
@@@@..@.@.@@..@@@@.@@@@.@@@@@@.@..@@@.@@.....@.@@.@@.@.@@@@@.@@@@..@.@@..@...@.@@@@@@..@.@@..@..@@@@@.@@@@.@...@@..@..@@.@@@@.@.@@@@@.@..
|
||||||
|
@.@..@@@..@@.@@@@@.@@@...@@@@@@.@@@@.@.@@@@@@@@@@@.@@@@.@@@@@@.@@@@@....@@..@@@@@@@...@.@..@@@.@.@..@@@..@@....@..@@@@@.@@@@@@.@@@@.@@@@.
|
||||||
|
@@@....@@@.@@@.@.@@...@@@..@@.@.@@.@@@.@@@@@@@@@.@@..@@..@@@@..@@@.@.@@..@..@@.@.@@@..@@@@@@@.@@.@.@@@@@.@@@@.@@@.@@@.@.@@.@@@.@@@.@@@..@
|
||||||
|
@.@@.@@@@@@@.@@..@@@@@@..@@@@@@@@.@@@@.@@@..@@.@@@@@@@@@@@.@@...@@@@.@..@@@.@@@@@@@@@@@@.@@@@@@@@.@.@@@@@@.@@.@@@@@@@@.@....@.@@@@.@@.@..
|
||||||
|
@.@@..@@@@@@@.@@@@@@.@..@@.@..@.@@@.@.@@@..@@@@@@@@@@@@@..@@@@.@@.@@@@.@@@@.@..@.@@.@.@@.@@@..@.@@@@@.@@.@@.@@.@@@.@@.@@@@@..@@..@.@.@@@.
|
||||||
|
.@.@..@.@@@@@@@@@@@@@@..@@@@..@@@.@@@@@.@@@.@@@@@@.@..@@@.@.@@@@@@.@.@@.@.@..@.@@@@@@..@..@.@@@@@@@@@.@@.@@....@.@@.@@@.@@@.@@.@@@@.@@@@@
|
||||||
|
...@@@.@@@.@.@.@@.@@@@@@@.@..@.@@@@.@.@..@@@@.@@..@@.@@@@@@@@.@@@.@@@@@...@.@@.@..@.@@@@@@@@.@.@@.@.@.@@@.@@@@@@.@...@..@.@@.@..@@@@@.@@@
|
||||||
|
@...@.@..@...@@@.@@...@.@.@.@@@.@.@@@@.@@.@@@@..@@.@@@@..@....@..@@...@.@@@@@@@@.@.@@@@@...@@@...@@@@@.@.@@..@@..@@@.@.@@@@@@@@.@@@@.@@@.
|
||||||
|
.@@@..@@.@@@@.@.@..@@@@.@.@..@@.@.@@.@@.@@@@@@.@..@@..@@.@@@@..@@@@@@@@..@@@..@@@@..@@@@@@@@@@.@.@@@..@@@@...@@@@@.@@@.@@@@@@@@....@@.@@.
|
||||||
|
@@@.@@..@@@.@.@.@.@@..@@@..@.@@@.@@...@@.@@.@@@@.@@@@@@.....@@@@@@.@@.@...@@@.@@@.@.@@@@.@@.@..@@.@@.@@@..@..@@.@@@..@.@@@@.@.@@@@..@.@@@
|
||||||
|
@@@.@@@@@@@.@@@@@.@.@@@@@@.@@....@@@.@.@@@@..@@.@@@@.@@...@.@@.@@@.@.@...@@@.@@.@@.@.@@.@....@@.@@@..@@@@..@@@@@.@@.@@@@@@@@@@@..@@@@@@@@
|
||||||
|
@..@.@@@@.@@@.@..@..@@@.@@@@@@@.@.@...@..@.@@@..@.@@@.@@@@@.@@@@@@@.@@@.@@....@@@.@@..@.@@@.@.@@.@.@.@@@.@.@.@@..@@@@.@@.@@.@@@@@@@..@.@.
|
||||||
|
@.@@@.@@.@@@@..@.@@@....@@@.@@@@.....@@@.@@...@....@.@.@@...@@@...@.@@@..@@@@.@.@@@@@@@@.@@@@.@.@..@@.@@@.@..@@.@@.@@.@@@@...@.@@@@...@@@
|
||||||
|
.@@@@@@@@@@@@@.@@@@.@@@@..@..@..@@@.@.@@.@@@..@@@..@@.@@.@@@@@@.@....@.@@@@@@@@@@.@@...@..@@..@@.@.@@@.@@@@@.@@..@@@..@@.@@@.@.@@@...@..@
|
||||||
|
@@@@@@.@...@@@...@.@..@@@@.@..@....@@@.@.@...@@.@@@..@.@@...@.@@@@..@@.@@@.@@@.@@@@@@@@@@@@@..@.@@.@@@..@@@@@..@@.@@.@@@@@@@@..@.@@@@.@@@
|
||||||
|
@@@@.@@...@@@@@..@.@@@@..@@.@.@@@@@@..@@@.@.@.@@@@..@@@@@...@@@.@@@..@.@.@@.@.@@.@@...@.@...@..@@@@@@@@@..@@@....@@.@.@@@@.@.@.@@..@@@@@.
|
||||||
|
.@@@.@@@.@@.@@@.@@..@@@.@.@..@.@.@.@@@@@@@.@.@@..@.@..@...@.@@@.@.@@@@..@@@..@@@.@@@@@@@...@@...@.@@..@@@@@@@@@.@@@@@@@@@@@.@@@@@.@.@.@@@
|
||||||
|
@.@@@@.@..@@@@.@@@@@.@@@@@@.@@@@.@.@@.@.@.@@@@@@@...@..@@@@@@@@@@.@.@@@..@.....@@@@...@....@@@@@@.@@@@@@@.@.@@.@.@....@@@@...@@@@..@.@@@.
|
||||||
|
@@@@@.@.@@@..@@.@.@@..@@@.@@@@@.@...@..@@@.@@@@.@@..@@.@..@...@.@@@.@.@@@.@@.@.@..@.@..@.@@@..@.@.@@@@.@..@@@.@@@@.@.@..@@@.@@@.@@@@@.@@@
|
||||||
|
@..@@@@.@.@.@@@@@@@@...@@@@@@..@@@..@@.@@..@@@@@..@@@@@...@.@.@@@@..@@@@@..@.@.@@@@.@.@@@.@@@..@..@@@.@@@..@.@.@@@@@@@@@@.@@.@...@@@@@@@@
|
||||||
|
@.@@.@@.@..@.@@@.@@.@.@@.@.@..@@@@.@@.@@@@.@@@@@@@.@@@..@.@@@@@..@.@@@@@@...@@@.....@.@.@@@@@@@.@@.@.@.@@@...@@@@@@@..@@@@.@@@.@@@@.@@@@.
|
||||||
|
@@@@.@..@.@@@.....@@@.@.@@.@@@@@.@@@.@@@@...@@.@.@.@@@@..@.@...@@@@@@@@@..@@.@@@@.@@.@@@@.@@..@@@..@.@@@@...@@@@.@..@@@@@@.@@.@..@@@.@.@.
|
||||||
|
@@@.@@@@@.@@.@@.@@@@@@@@.@@..@.@@...@@.@@..@.@@@@@@.@..@.@@@..@@@.@@.@@.@....@@......@@.@@@..@@@..@@.@@@...@@@@@@@.@....@@@@.@@@@..@.@@..
|
||||||
|
@@@@@@.@....@@.@@.@@@...@@.@.@@@.@.@@@@@.@@@.@..@@@@@@.@..@@@.@@@.@..@@.@@@@@@..@.@@@.@@@.@.@@@..@.@@...@@@.@@.@@@@@@@@.@@@@.@..@@@.@..@@
|
||||||
|
@@.@.@.@@@@@@@.@@.@@@..@@.....@.@@.@@@.@@@.@@@@@@@@@@.@.@.@@@.@@.@.@..@@@@@@@@.@..@..@@@@@@@@@.@@@@@@..@.@..@..@@...@@@@.@.@@@..@@@@.@.@@
|
||||||
|
.@@@@@.@.@@@@@@@@@@@@@.@@..@@@@@@..@@.@@@@@@@@.@@...@@@@@@.@.@.@@@..@@...@@.@.@@@@@@@@@.@@...@@@@@.@@@@@..@@@@@@.@@@...@@@.@@@@@@@@@@....
|
||||||
|
@@@@@@.@.@.@.@@.@@.@@@..@..@@.@@..@@@@.@@.@.@.@@.@@@@@@@@..@@@.@.@.@.@@@@.@......@.@.@@@@@@@..@@@@@@.@..@@.@.@.@@..@..@@@.@@@@@@.@@@@.@@@
|
||||||
|
....@@@@@@@@@@@@@@@.@@..@@.@@@@@..@...@.@@...@@..@@@@@@@@@@@@@.@.@.@@@.@.@@.@.@@@.@@@@@@@.@@@@.@@@@@.@@@@@@@..@@@@@...@...@@.@@@@@@..@@@.
|
||||||
|
@@@.@@@.@.@@@@@.@@@@@.@@@..@@..@@@@@..@@@@.@@...@@.@..@..@@@@....@.@.@@.@@@@.@....@@@.@@..@@..@@@@.@@@@@..@@@...@@@.@@@@@@@@@@@@.@..@@@.@
|
||||||
|
..@.@.@@@@..@@@@..@@@@.@@@.@..@@.@@@@@@.@@.@.@.@..@@@@@.@@@@..@.@..@.@@@@@.@.....@@@...@.@@@@..@..@..@.@@.@.@@@.....@@.@@.@@...@@...@@@@.
|
||||||
|
@.@@@..@@....@..@@.@@.@.@@.@.@.@@@.@@@@@....@...@@@.@@@.@.@@.@.@@@@@@.@@@.@@.@@@@@@..@@@@.@..@.@@@.@.@@@...@.@.@..@@@@.@@@@@@.@.@@...@@@@
|
||||||
|
@@.@....@@@@@..@@@..@.@@.@@@..@@@@@@@@@@@@@@@....@@.@@@@.@@@@.@.@.@@.@.@.@@@@@@@@.@@.@@@@@@@..@.@@@@@@@.@...@@@@@@@....@@@..@....@.@@@.@@
|
||||||
|
@.@.@@@@@@@@@.@@@@@@.@...@@@.@@@..@@@@.@.@@.@@@.@.@@.@@@@@.@@@.@@@@.@@..@@.@.@@.@@.@@@.@.@@@@..@@@.@@@.@..@@@@@.@@..@@..@@...@@@@@@@@@@.@
|
||||||
|
.@@@@@@@@@.@..@@.@@@@..@..@@@@@.@@...@.@@.@.@@@@@@@@@.@@@@....@@.@@@@@...@...@.@@@@@.@@@@@@.@..@@..@.@@@@@.@@@@.@@@@.@@.@@@.@@.@...@@.@@.
|
||||||
|
..@@@@@@@.@@@@@@@@@@@@@@..@@@.@@@@@@..@@@.@@.@@@@@@@@@@@.@.@@..@@@@@.@@@.@.@@@@..@...@@.@@@@.@@@@.@@@@@..@.@@@@.@@.@.@.@.@@@.@@.@@@..@@@.
|
||||||
|
@@@@.@@@@.@@.@@@@@@@.@.@@@@@@.@.@.@.@@..@@....@.@@@@@.@..@.@@...@.@@@@@@@.@.@@@.@.@@.@@...@@@.@..@@@@@@...@@..@@@.....@.@.@@@@@@...@@@@@@
|
||||||
|
@..@..@@.@@@..@@.@@.@.@@@...@@.@@@.@@.@@@.@...@@@@.@.@@.@@@.@..@@@@.@@@..@@..@@@@.@.@..@..@@.@.@@@.@...@@@.@@@@@@@.@@@.@.@..@..@.@@@@@.@.
|
||||||
|
@@@@..@@.@@@@.@@@@...@.@@@@@@@.@.@@.@@@..@@.@@@@@@@@@@@.@@@..@.@@@.@@@@..@@@@.@@@@.@..@.@@@..@..@@.@@@@@@.@..@@@@@@@...@.@@.@...@.@.@@..@
|
||||||
|
@@.@@..@..@@@@@@@@@@@@@@..@@@@@@@.@@@@@...@@@..@@.@@..@.@@@@@@@@..@@.@.@@.@@@@@...@@@@..@@@@@@@@@@@@.@@@..@..@@@@.@@@@@@.@@@@@@@.@...@@@@
|
||||||
|
@@@@@.@@.@@...@.@.@@@@@@@.@@@....@@@@@@@..@@..@..@@@@@..@@@.@@@@@@@@@.@@.@.@@@.@@...@@@.@@@.@@.@@@.@..@@@@@@.@@@@@@@@@@@...@.@@@@@@.@@@@.
|
||||||
|
.@@@@@@.@@@@..@..@@..@@@.@@@@...@@@@.@..@@.@@@@.@.@.....@..@.@@...@@@@.@.@..@@@@@@@..@@@@@@@@@@@@@.@..@@@@.@.@..@@@.@@@@@@..@.@@..@.@@.@.
|
||||||
|
@@@.@@@@@...@@@.@@@@@.@@@@@@...@@.@@.@@.@@@@@@@@.@@@@@@.@@@@..@.@@.@@@@@@.@.@@.@@@.@@@@.@@@@@@@@.@@@@@@@@.@@.@@@.@.@@@@@@@.@.......@.@..@
|
||||||
|
@@@@@@.@..@...@..@..@@@..@@@@.@@..@@.@@@..@@.@@@@.@@@@@...@.@@@.@@@@..@...@@@...@.@@@.@@@@@@.....@@@@..@.@@@.@@@@@@@.@@@.@.@.@.@@....@..@
|
||||||
|
@@@..@@@.@..@@@@....@.@@@.@@@@.@@@@@@@.@@@.@@@.@@.@@@.@@@@.@@@@.@@@@.@@..@@@@@@@...@@@.@@@@@@@.@@.@.@@@@@@@@@@@@@@@@@@@.@.@@@@.@@@.@.@@@.
|
||||||
|
@..@@@@@@@@@@@@@.@.@.@@@@..@.@@@@@@.@@@@..@..@@@@.@@..@@.@@@@@@.@@@@.@.@@@@@.@@@@@@.@@.@@...@@@@..@@@@@@@@@.@@@.@@@@@@@@@@.@.@@@@@@@@.@@@
|
||||||
|
@@....@..@..@...@@@@.@...@@@.@@.@@@...@..@.@@..@@@.@@@@@@...@.@@@.@@@@@.@@@@...@@@@.@@@@.@.@@.@@@@@@@.@.@..@@@@@@@@@@..@.@@@@.@..@@@@@@.@
|
||||||
|
.@.@@@@@@@@..@@.@@@.@.@.....@@@@.@@@@@@..@...@@@@.@.@@....@.@@@@@.@.@@@.@..@.@@@@@@@@@.@@@@@@@@@@@@.@.@@.@...@@@@.@.@..@.@@@@.@..@@.@@@@.
|
||||||
|
@@@@@.@.@@@@@@...@@@@@@@@@@@...@...@.@...@..@@.@.@@@.@.@..@@@@@@@@.@.@@@@@.@@@@@@@@@.@....@@@@@@.@@@@@@@.@@@@.@@@@@@@@@...@..@@...@@.@@@@
|
||||||
|
@..@.@.@.@@@..@@@..@@@@@@.@@@@@@@@@.@.@.@.@@@......@..@@@@.@@@.@@.@@.@....@.@@@...@.@@@.@@@.@..@...@@@@@@@@@@@@@.@.@@@.@@@@@@@@@.@@@@@@@@
|
||||||
|
..@@.@@@@@@@@@..@@...@..@@@@.@@.@@@@@@.@@.@.@..@@@@@@@@...@@@@@.@@.@@@@@.@.@@@.@@@@.@.@.@..@@@@@@.@@@@@@.@.@@@@....@@..@..@@..@@..@@@.@@@
|
||||||
|
@@@.@@@@@@@.@@@@@.@@.@.@@.@@@@..@@.@@@@@@...@@@@@@..@.@@@.@@.@@@@@@@@@@@@@....@@@@..@@@.@@@@@@@@@.@.@@@@@.@@@@@@@@.@@@@.@..@@.@.@.@.@@@@.
|
||||||
|
@.@@@@@@@@@.@@.@@.@@@@@..@.@@@.@..@....@@@@.@.@@@@.@@.@.@@@..@@..@@.@@@@@@@@@@@@..@.@@@@.@....@@.@@@@@@.@@@@@@.@.@@@@@.@.@@.@@@@.@@..@.@.
|
||||||
|
@.....@.@@@.@.@...@.@.@@@@@@@@@@@@..@.@@@@@@@@@@@@.@@@..@@@..@@@.@@@@@.@@@@@@@@@@@@@..@@@@.@..@@@@..@@..@@@@@@@@@@..@@@@@..@@@@.@@@@@.@@.
|
||||||
|
.@@@@..@.@@@@@...@@.@@@.@@@@@@@@@@...@..@@.@.@..@@@@@@@...@@@@@@@.@.@....@.@.@@@.@@.@@@@.@@.@.@@@@@@.@...@@@@.@@@@.@.@@@.@@.@@.@@@@@.@@@@
|
||||||
|
.@@@.@@@@@@@@@.@@@@..@@@.@..@@.@@@.@@@@@..@@@..@..@.@.@@@....@@@..@.@.@@.@@.@..@@.@@@@.@@@@@@.@...@.@@@@@.@.@..@@@..@.@...@.@@....@@@@@@@
|
||||||
|
@@.@.@@@@@.@.@..@..@@@@.@@.@@..@@@.@@.@@.@@@.@.@@@...@..@.@@..@@@....@..@@@.@@@@@@@@@@@@@@...@.@@..@@@.@@...@@.@@@..@@@@@@@......@.@@@@@@
|
||||||
|
@.@@@..@@.@.@@@.@.@..@.@...@@.@@..@@@@@..@@....@@@@@@.@.@.@@@.@@@@@@@@@@@@@@.@@.@@@@@@.@.@@@...@@@@.@@..@...@.@@.@@@@@.@@@.@@@@@@@.@@..@@
|
||||||
|
.@.@@.@@@.@.@@@@@@..@.@.@@.@@@.@@@@@...@@@@@@@@.@@@....@...@@.@@@@.@...@@@.@.@@@@.@@@@.@@@@@@.....@...@.@@@@@..@..@.@.@...@..@@..@.@@@@@.
|
||||||
|
@@@@.@@.@@@@@@@@@..@...@@@@@@@@..@@@.@@@@@@@..@@@.@@@@@@@@@..@@@@@.@@@@..@@@@@@@@.@@@@@@@@@@@@@@@@@@@@@@.@@..@@@@@@@@@@@@.@@@@@.@@@@@.@.@
|
||||||
|
@@.@@@@@.@@@@..@.@@..@.@@@@.@..@@@@.@@@@@.@@@.@...@@.@@@@@..@@@.....@.@@@@.@.@@@@@@.@@..@..@@@@.@@@.@@..@.@@.@@...@.@@@@.@@@@@...@@.@@@.@
|
||||||
|
@@@@@@.@.@.@@@.@@.@@..@@.@@.@@@..@.@.@..@@.@@@@@@@.@.@@..@@@@@@@@@.@.@@..@@@@@@@@.@.@.@@@@@@@@@.@@...@@@.@@@@....@@.@@.@@..@@@.@.@.@@@.@.
|
||||||
|
@@@@@...@@..@.@@.@.@.@@...@@..@@@@@@@@@.@@@.@@@.@@...@@@@.@@@.@@@@.@@..@@@@...@.@@@@.@.@@......@@@@@@@..@@@.@@@..@..@@@@@.@@@.@@.@@....@@
|
||||||
|
@..@@.@@@@@@@@....@.@.@@@@@@....@@@@.@.@@@.@.@@@@@@@.@@@@@@@..@@.@@@.@..@@@@@@.@.@..@@@.@@.@.@@@@@@@....@@.@.@@.@.@.@@@.@@@...@@@@@.@@@..
|
||||||
|
.@@@@..@@@@.@.@@.@@@@....@@@..@.@.@.@.@@@@@@@@.@.@.@@@.@@.@@..@@.@@@@.@..@@.@@..@@@.@.@.@..@@...@.@@@@@.@..@@@@@.@...@.@@@@@@@@@@.@.@@..@
|
||||||
|
.@...@.@@@...@@@.@@@.@.@@@@@@.@.@@@@@...@@@@@@@@@@@..@@.@@@@@@...@@.@.@@@.@.@@@.@@@..@@@@.@@.@.@@@@.@@@.@@@@@@@@@@@@.@@@@@@@@@@@.@@@@@.@@
|
||||||
|
@.@@@.@@@@@@.@@.@..@.@@.@@.@@..@.@@...@@@@@@@@.@@@..@.@.@.@@@.@@.@@@.@.@@.@@@@@....@@@.@@.@@.@@..@@@..@@@@@@.@@@@@@@@@@@@.@@.@@@@@@@@@.@.
|
||||||
|
@@.@@@@@@.@.@@...@@.@@@@..@.@.@@.@@@.@...@@@@..@@.@@.@@.@.@@@@..@.@@@@.@@@..@@.@.@.@@@@@@@@@......@@.@@@@@@...@.@..@.@@@@@..@..@.@@.@@..@
|
||||||
|
@@@@@@..@@.@@@@..@@@.@@@@@..@@@.@@@@@@@.@@@@..@@@@.@@@.@.@@@@@@..@@@....@@@...@@@@@.@.@@@@.@.@.@@@@...@@..@@..@@@@@@..@@.@@.@@.@@.@@@.@..
|
||||||
|
@@@...@.@@@@@.@@..@.@.@@@@@@@@.@@.@.@.@@..@@..@@@@@@@@@@.@@@@..@@.@@@@@@@@@.@.@@....@@@@.@@@@@.@@@..@@@@@@@@..@@@@@@@@@.@@..@.@@@@..@...@
|
||||||
|
@@@@@@@@.@@@@@@@@@@@@@@....@..@@.@.@@@.@@@@@@@@@@.@@.@@@@@@@@.@....@..@@.@@@.@...@@@@.@@@@@@.@@@@..@@@@.@@..@.@@.@@@@.@.@@@..@@@@@@@@@@.@
|
||||||
|
...@@..@.@@@@@@.@@@..@.@@.@@..@@..@.@@@.@.@.@@@@@@.@@@@@@.@@@.@@@@.@@@@..@.@@@.@...@@.@....@@@.@@@@@@.@@..@@.@@@.@.@@.@.@.@@@@.@.@@.@@..@
|
||||||
1186
data/05.in
Normal file
1186
data/05.in
Normal file
File diff suppressed because it is too large
Load Diff
35
day01.sql
Normal file
35
day01.sql
Normal file
@@ -0,0 +1,35 @@
|
|||||||
|
with
|
||||||
|
instructions as (
|
||||||
|
select
|
||||||
|
case when line[1] = 'L' then -1 else 1 end as dir,
|
||||||
|
cast(line[2:] as int) as amount,
|
||||||
|
row_number() over () as id
|
||||||
|
from read_csv('data/01.in', header = false) file (line)
|
||||||
|
),
|
||||||
|
|
||||||
|
positions as (
|
||||||
|
select 50 + sum(dir * amount) over (order by id) as abs_pos
|
||||||
|
from instructions
|
||||||
|
),
|
||||||
|
|
||||||
|
clicks as (
|
||||||
|
select
|
||||||
|
dir as click,
|
||||||
|
row_number() over (order by id) as click_id
|
||||||
|
from instructions, generate_series(1, amount)
|
||||||
|
),
|
||||||
|
|
||||||
|
all_positions as (
|
||||||
|
select 50 + sum(click) over (order by click_id) as abs_pos
|
||||||
|
from clicks
|
||||||
|
)
|
||||||
|
|
||||||
|
select
|
||||||
|
(
|
||||||
|
select count(*) from positions
|
||||||
|
where abs_pos % 100 = 0
|
||||||
|
) as p1,
|
||||||
|
(
|
||||||
|
select count(*) from all_positions
|
||||||
|
where abs_pos % 100 = 0
|
||||||
|
) as p2;
|
||||||
39
day02.sql
Normal file
39
day02.sql
Normal file
@@ -0,0 +1,39 @@
|
|||||||
|
with
|
||||||
|
bounds as (
|
||||||
|
select
|
||||||
|
unnest(string_split(trim(content, '\n'), ',')) as f,
|
||||||
|
string_split(f, '-') as bounds,
|
||||||
|
cast(bounds[1] as int64) as low,
|
||||||
|
cast(bounds[2] as int64) as high
|
||||||
|
from read_text('data/02.in')
|
||||||
|
),
|
||||||
|
|
||||||
|
candidates as (
|
||||||
|
select
|
||||||
|
unnest(range(low, high + 1)) as num,
|
||||||
|
cast(num as string) as num_str,
|
||||||
|
len(num_str) as len
|
||||||
|
from bounds
|
||||||
|
),
|
||||||
|
|
||||||
|
part1 as (
|
||||||
|
select sum(num) as solution
|
||||||
|
from candidates
|
||||||
|
where num_str[: len // 2] = num_str[len // 2 + 1:]
|
||||||
|
),
|
||||||
|
|
||||||
|
part2 as (
|
||||||
|
select sum(num) as solution
|
||||||
|
from candidates
|
||||||
|
where exists (
|
||||||
|
select stride from range(1, len) as range (stride)
|
||||||
|
where
|
||||||
|
len % stride = 0
|
||||||
|
and repeat(num_str[: stride], len // stride) = num_str
|
||||||
|
)
|
||||||
|
)
|
||||||
|
|
||||||
|
select
|
||||||
|
part1.solution as p1,
|
||||||
|
part2.solution as p2
|
||||||
|
from part1, part2;
|
||||||
60
day03.sql
Normal file
60
day03.sql
Normal file
@@ -0,0 +1,60 @@
|
|||||||
|
with recursive banks as (
|
||||||
|
select unnest(split(content, e'\n')) as bank from read_text('data/03.in')
|
||||||
|
),
|
||||||
|
|
||||||
|
banks_1 as (
|
||||||
|
select
|
||||||
|
(select arg_max(i, bank[i]) from range(1, len(bank)) r (i)) as i1,
|
||||||
|
bank
|
||||||
|
from banks
|
||||||
|
),
|
||||||
|
|
||||||
|
banks_2 as (
|
||||||
|
select
|
||||||
|
i1,
|
||||||
|
(select arg_max(i, bank[i]) from range(i1 + 1, len(bank) + 1) r (i))
|
||||||
|
as i2,
|
||||||
|
bank
|
||||||
|
from banks_1
|
||||||
|
),
|
||||||
|
|
||||||
|
banks_12 as (
|
||||||
|
select
|
||||||
|
12 as i,
|
||||||
|
bank,
|
||||||
|
0 as r
|
||||||
|
from banks
|
||||||
|
union all
|
||||||
|
select
|
||||||
|
i - 1,
|
||||||
|
bank,
|
||||||
|
(
|
||||||
|
select arg_max(j, bank[j])
|
||||||
|
from
|
||||||
|
range(
|
||||||
|
r + 1,
|
||||||
|
len(bank) - i + 2
|
||||||
|
) m (j)
|
||||||
|
)
|
||||||
|
from banks_12
|
||||||
|
where i > 0
|
||||||
|
),
|
||||||
|
|
||||||
|
part1 as (
|
||||||
|
select
|
||||||
|
sum(
|
||||||
|
cast(bank[i1] as int64) * 10
|
||||||
|
+ cast(bank[i2] as int64)
|
||||||
|
) as solution
|
||||||
|
from banks_2
|
||||||
|
),
|
||||||
|
|
||||||
|
part2 as (
|
||||||
|
select sum(cast(10 ^ i as int64) * cast(bank[r] as int64)) as solution
|
||||||
|
from banks_12
|
||||||
|
where i < 12
|
||||||
|
)
|
||||||
|
|
||||||
|
select
|
||||||
|
(select solution from part1) as p1,
|
||||||
|
(select solution from part2) as p2;
|
||||||
95
day04.sql
Normal file
95
day04.sql
Normal file
@@ -0,0 +1,95 @@
|
|||||||
|
with recursive
|
||||||
|
|
||||||
|
raw as (
|
||||||
|
select split(content, e'\n') as content from read_text('data/04.in')
|
||||||
|
),
|
||||||
|
|
||||||
|
lines as (
|
||||||
|
select
|
||||||
|
string_split(unnest(content), '') as line,
|
||||||
|
generate_subscripts(content, 1) as row
|
||||||
|
from raw
|
||||||
|
),
|
||||||
|
|
||||||
|
grid as (
|
||||||
|
select
|
||||||
|
unnest(line) as ch,
|
||||||
|
generate_subscripts(line, 1) as col,
|
||||||
|
row
|
||||||
|
from lines
|
||||||
|
),
|
||||||
|
|
||||||
|
rolls as (
|
||||||
|
select
|
||||||
|
row,
|
||||||
|
col
|
||||||
|
from grid
|
||||||
|
where ch = '@'
|
||||||
|
),
|
||||||
|
|
||||||
|
accessible as (
|
||||||
|
select
|
||||||
|
pos.row,
|
||||||
|
pos.col
|
||||||
|
from rolls pos, rolls adj
|
||||||
|
where
|
||||||
|
adj.row between pos.row - 1 and pos.row + 1
|
||||||
|
and adj.col between pos.col - 1 and pos.col + 1
|
||||||
|
group by pos.row, pos.col
|
||||||
|
having count(*) < 5
|
||||||
|
),
|
||||||
|
|
||||||
|
remove (row, col, present, level) as (
|
||||||
|
select
|
||||||
|
row,
|
||||||
|
col,
|
||||||
|
true
|
||||||
|
from rolls
|
||||||
|
|
||||||
|
union all
|
||||||
|
|
||||||
|
select
|
||||||
|
pos.row,
|
||||||
|
pos.col,
|
||||||
|
pos.present and 4 < (
|
||||||
|
select count(*)
|
||||||
|
from remove adj
|
||||||
|
where
|
||||||
|
adj.present
|
||||||
|
and adj.row between pos.row - 1 and pos.row + 1
|
||||||
|
and adj.col between pos.col - 1 and pos.col + 1
|
||||||
|
)
|
||||||
|
from remove pos
|
||||||
|
where
|
||||||
|
exists (
|
||||||
|
select
|
||||||
|
pos.row,
|
||||||
|
pos.col,
|
||||||
|
count(*) as c
|
||||||
|
from remove pos, remove adj
|
||||||
|
where
|
||||||
|
pos.present
|
||||||
|
and adj.present
|
||||||
|
and adj.row between pos.row - 1 and pos.row + 1
|
||||||
|
and adj.col between pos.col - 1 and pos.col + 1
|
||||||
|
group by pos.row, pos.col
|
||||||
|
having c < 5
|
||||||
|
)
|
||||||
|
),
|
||||||
|
|
||||||
|
removed as (
|
||||||
|
select
|
||||||
|
row,
|
||||||
|
col
|
||||||
|
from remove
|
||||||
|
group by row, col
|
||||||
|
having bool_or(not present)
|
||||||
|
),
|
||||||
|
|
||||||
|
part2 as (
|
||||||
|
select (select count(*) from removed) as solution
|
||||||
|
)
|
||||||
|
|
||||||
|
select
|
||||||
|
(select count(*) from accessible) as p1,
|
||||||
|
(select count(*) from removed) as p2;
|
||||||
64
day05.sql
Normal file
64
day05.sql
Normal file
@@ -0,0 +1,64 @@
|
|||||||
|
with recursive
|
||||||
|
|
||||||
|
raw (line) as (
|
||||||
|
select * from read_csv('data/05.in', header = false)
|
||||||
|
),
|
||||||
|
|
||||||
|
ranges (low, high) as (
|
||||||
|
select
|
||||||
|
cast(spl[1] as int64),
|
||||||
|
cast(spl[2] as int64)
|
||||||
|
from (
|
||||||
|
select split(line, '-') as spl
|
||||||
|
from raw
|
||||||
|
where contains(line, '-')
|
||||||
|
)
|
||||||
|
),
|
||||||
|
|
||||||
|
ingredients (id) as (
|
||||||
|
select cast(line as int64)
|
||||||
|
from raw
|
||||||
|
where line <> '' and not contains(line, '-')
|
||||||
|
),
|
||||||
|
|
||||||
|
part1 (solution) as (
|
||||||
|
select count(*) from ingredients
|
||||||
|
where exists (
|
||||||
|
select
|
||||||
|
low,
|
||||||
|
high
|
||||||
|
from ranges
|
||||||
|
where id between low and high
|
||||||
|
)
|
||||||
|
),
|
||||||
|
|
||||||
|
merged (low, high) as (
|
||||||
|
select * from ranges
|
||||||
|
|
||||||
|
union
|
||||||
|
|
||||||
|
select
|
||||||
|
r1.low,
|
||||||
|
case when r1.high < r2.high then r2.high else r1.high end
|
||||||
|
from merged r1, merged r2
|
||||||
|
where
|
||||||
|
(r1.low < r2.low or (r1.low = r2.low and r1.high < r2.high))
|
||||||
|
and not r1.high < r2.low and not r2.high < r1.low
|
||||||
|
),
|
||||||
|
|
||||||
|
part2 (solution) as (
|
||||||
|
select sum(m1.high - m1.low + 1) from merged m1
|
||||||
|
where not exists (
|
||||||
|
select *
|
||||||
|
from merged m2
|
||||||
|
where
|
||||||
|
(m1.high <> m2.high or m1.low <> m2.low)
|
||||||
|
and m1.high <= m2.high
|
||||||
|
and m1.low >= m2.low
|
||||||
|
)
|
||||||
|
)
|
||||||
|
|
||||||
|
select
|
||||||
|
part1.solution,
|
||||||
|
part2.solution
|
||||||
|
from part1, part2
|
||||||
Reference in New Issue
Block a user