diff options
author | kartofen <mladenovnasko0@gmail.com> | 2023-12-03 01:11:21 +0200 |
---|---|---|
committer | kartofen <mladenovnasko0@gmail.com> | 2023-12-03 01:11:21 +0200 |
commit | a3763a356d6adcf6d99cbca49d33848271a2e408 (patch) | |
tree | ef1ecfdbebc605a0a31c496a570a0de5ba1d2049 | |
parent | 555091332de32b1d3b36c888ed21898aae540750 (diff) |
day one 2023
-rwxr-xr-x | Advent-of-Code-2023/aoc-1/a.out | bin | 0 -> 20664 bytes | |||
-rw-r--r-- | Advent-of-Code-2023/aoc-1/input.txt | 1000 | ||||
-rw-r--r-- | Advent-of-Code-2023/aoc-1/main.c | 259 | ||||
-rw-r--r-- | Advent-of-Code-2023/aoc-1/sample.txt | 7 |
4 files changed, 1266 insertions, 0 deletions
diff --git a/Advent-of-Code-2023/aoc-1/a.out b/Advent-of-Code-2023/aoc-1/a.out Binary files differnew file mode 100755 index 0000000..da999db --- /dev/null +++ b/Advent-of-Code-2023/aoc-1/a.out diff --git a/Advent-of-Code-2023/aoc-1/input.txt b/Advent-of-Code-2023/aoc-1/input.txt new file mode 100644 index 0000000..a67973d --- /dev/null +++ b/Advent-of-Code-2023/aoc-1/input.txt @@ -0,0 +1,1000 @@ +14gxqgqsqqbxfpxnbccjc33eight +eight2sevenkl +mrjstg5onetwoeightgcczx8vgrgl +9246 +ninetwo2crrqk2grsctqxqbcrmrdsqbrz9eight +five6dlhx1 +29qhsdqqtgrk4 +mjgtrjnlttxjlsixsix5 +bgnnvfsnbpx29vsjrlmgmsqthreeqxvclkhlv +sevennine3gsmxncqlqvfktxrtcone +2mkzrqlmhsveight1sjtwo2 +rrrbvnrvnqfdh86 +94threeqrhkcpkeightfour +four83 +9ninehbsgkcthree1nineeightsix9 +57zfcgpf68 +hbonefourfour8lsnfgvf3 +seven79rqtqvjddc +two6six7eightqnmnppctxjrxbdxbdmbfkmv +9rdvkbxclk9fivecrxmtpzsxn8cmrzttlfour +nztfnthree2 +nxhjcqzlcxgdkmcfggc261gbt +xqfcdfdsrlhdktdjshllqgqshzmf7hpcdgdfcvntczdxxfqbvz +sbf43g +vsm922three7 +nthree1 +3eightjvtqcb1lkgkzhbgvl9eightfn +tfvv2zz5xmckbc1sevenfour7 +fivesix6two7cptgpfpd +3skfjrzbjpeightdkkkjq +68onefourxmznzlfivesixfqmfchn +12rzcscnkxsbc2ninetwo +jrmmvsdjvftgnrz33five +bhdxxmb36ninedmrlrstrmrbvz +1seventhreenbsth136kzrgdvvjp +7nrc6xpl +fourseven4nineone +8zxncrhffcmq9threeeight +5seveneight4three9 +8ghsxbzoneightg +qtwonesixtwosixvjmnhqbbx5 +sp1psqkctzqnldbdhqsmgsixfivepjnnvsxdldtwoseven +9ninethreefqqlztnrtgcbfourxdgltgft +zsix14sevenhqkgfh +nt3 +dhdsktwo9 +8cmjzrsmr +4bdspt8 +qvzgxjp7six +ninethreexqvzzqhjsthreefivetwo1 +kzhsgr5tpzhxeightpqkfj +twozclthmcx1phkcvgrlbj7fhmcph3eight +9lkctcvgxr2two8rxgkdbx +khfgllh7kchfq9xbnrqrseven +ninekqmvfour81seven +xsfpksix65eight +eightf24oneone +24581snlbjpfronenine +nine3eightjqshqxscvzvskspcmdzd49 +6mfqf5one +zrzzlchrfl167n1 +nsxqfspq9 +7mggsvthrnckcsctjsxlmxghqeightsix13 +sbpkxkmjkxcmg4 +eightonethreevqkjkxnnine2 +kntj2vkcnrkjonefnqddll6 +zlbnprltbkgmzpvtqmvzhpvhrb3ntrzhkrbvd6twoltkpsccvbk +6seven5196fivesix +vj8 +seven5fourthreeeight5 +lqzkbvdtxs3hbqr +7gmfzfcnrone66nqvkmthreekdhfkrhone +nsxftsvssone2fivefive1rcvlzltfdzcgsh +8five1eight +7ljfbvnrbghgkhstwo6vmnhxdteightfour +hdnxc4zjqrbr +5ghrjjbfshonek1sixrvnnkhpd5 +threetjxxlvqfvdcj852dkxlthree +xbpqlbrgcbkzvbjdt8 +cbzeightwo7npgjjxfzrvz66 +zktrxkjpchjxzmpq2 +five1lbdhrsix +5qldpfkqjkfjdzpfhf86 +vnbrnsskxphxv22 +4chnggbxmssnine3 +4k9one +2twoneh +6kgbvpsl5threecxf +562six6 +tsdvbzxpkqbkrpvht33hxhvmjnltwo3 +7fourone +ninesix2sixsix1fivenine +fourbqvbqftvzz88sjszkgxhrtlshkdjq +sfsrfsevenpgpmffthreezzsfb3 +8fivekvmzz4rlrscnxmx15 +jvteightwozhqsnvffxg3rsjmszc7fssnbhrtwo +fivenineqsvpgbkdxlp355nine +9jbfive +zsxzdcvsjln65 +nvcc52twonine83fq +gcnpqqfhq2 +jspfdkpxl4fourbstlcvdhxhjdgxvpzbvltwo6 +8sixsix +fourtwohsqhmnjmph7 +one3eighttwo +tshglpdmjbsgsoneplbjqcsrxseven8 +42sgr296mpkdz39 +bxsevenone25two +two8fivefour +three4cgjttdmfqonenine +eight5sixeightmxzzqmt795 +threebtnlmrrqgnine9fivezdzgldkxnbvhsvzqnine +one14tqvqgn1ninevkzhrqfqdjprzxb +cqqnine52cjmteightgbb +vhhkrrbhlp9dseight +fjzfmqv1bsvqbtpvvzcvqvxnlptk +five6three1zvgznsrvnpmnine +cfkxfmeight18hgkclhmcfcfsjzkztwothree +fivesevenonejmmrjvhznffive4jbrvdhlcpj +gbboneight47xfmqzt8 +sixmjnfmjtsszvc4sevennineonexc +kfsnggdldp33four +56hj2lqncdfghdbgdkzpkr +63five519bztrxx5 +3eight3six9xvdfhrcmsm +drcjrlst5ninefourxcm +4five3dmjbnbeightvxtbbvxdpfourjvj3 +lnmqnine855four17twoeightwolx +lnkffrtmv9t +mmhrvrpbvrcmpczvknkfourcqktxx73qbgd +khbrlcvdpxdkljvkhnfrvtpmbeightgzms2 +shbr9fzbvzhhqmnnine76 +x93 +3onec +v5xskfrg19five +ncmtbgdkfour7fiveeightfour4nine1 +3dtdjs38ggfljpdvv +fourthreevfpmztnzzcf96eight1 +onesjmdmmmcgnvhdnczfzznrvrggkgpcpcggqpkkkcfbq6qpsv +5nvhksixtwothree +d4qhmsljqhmcqlxln2dbd64 +zrshqtseven9zkpmzksqcsptfkkn +9pk +51jnqbzgnlhcglfour5three +8snxnxv3817 +tsvd4 +lzfxkxrcktjlvzbnsixfourthreenineeightone4 +lxdz9326threefouroneseven +6zkgmhktdnfive +zonekfbbcqcsdbkc4fivexpnhssdgbbnine +8zcdxcbhm7seven +1fldmtvgnine39eightdrmrtzkcthree7 +8sixxlztjhjkxtppmrtfour +threekvjx68twofiveqtzfg2fbhnhrdztv +6pgvzdbgjnlctwofourxzpc3xzdc +sixdxpnthgkfmddvqhrvsixsevenx4q +ch29onepqnine +sixlnh68 +1one5rqxz6nine7 +cone9 +fourseven3kddtmbjhnkz9kxhzspvtdngvsix +3sixnrjcxv1 +onemdts29zrbh +beightwo2eight816nnzfhptjhfqvqq +lfmxzp44cqkthree +gl4qsevengltwosix +2eight3qqkksrsevenxkndsxt +eightzxrflknj9jpbmt +knqjgjjjmkninezzfnbcdmqctwozskxsgd1655 +qpfdjsmsqfourfiver49f +vsix1xpglmcbdp +vgqjvzzcct7one674 +4csdttrsd58fivesixtwofive +bslfsjhrl8cszqrppqskthreenine +997foursixeighttftrnktp1 +3ndqmpzs6jkpcvjdltgbfgvlcn2 +lsxprcgkfivesix8eight9onenbdxqbl +seveneight3eight +eight7sevencvvshpgfg +8zg7two +5sixsixtwo +six7two +jjcxmsixhbtvfx2twoxs +9xtg +3onelvrpcvxk +ninetqzpbhxsspcfjlvsg3qlnbbqfxdqnine4one3 +xplhfgfour49 +jdrzrkkzdkgvhsvbm6bqfgpjbvhxlhtxhhpmmtmvqbgnmzpkm3 +hrjqkmvv1bzm2krs5 +vfztwonepdlcn96seven5 +1mpkqmccqqdsmhdgjjgrrtsbconehpfgfnjtxtqv5 +one9qn8threeeightnmqvfjkklg3 +5kgkst4ninegnqnjgmtdpfzspmkk +pmggrbfxghr53eight7mjlzgzv +4fourone +lbjfvxjzd7fivevllrtvfkmeight6 +xtl9 +ninevonevljrvx9 +sevensix7sixhbeightone +npzmcdtdqfpvonenine9rsktdrrnz9six +4six55 +eight646gdvfkjqsvnczbxtwo +5seven5jthree +cfourfhmxqjmseventhree2sgkxm18 +mfxnnjjxtjzlljgcnfpvb6cmknzb +4796 +kzxfnrqktwohmp9cclstwo +vgzgmc1zlsch +lvpnb1five216mbdxgvfkcg +3onezjnmv9fourj +two8vmpfmqmq6 +p8 +4oneeight45 +827eightsnvlrskzlbnineeightbtngkb +kdfxtjj2 +csthreesevennine7seven +hqqjrzkkkh84 +six42four +nine259five +8jngjtkdnine +3ph +8gccpsqfourtxtlbvmvb8n +oneonesix7jdkzfxkdvttwo26 +xkfsdgkjt34vq +98twosjrr5eight +foursixfive9 +17vmxlvqpqmvnfchhmxmdcpzgrsjl3nine +pmzscpthreevone3kdgqldjf48 +dzhoneightonevxtzqsqxxpgtgrdl73 +4threebbsttfhbdtwofivezsvspjp +jlstdnkjgdxszmpv2tgvpbdhdrkdjjvdbscv +4mqqxrsfrfhsbxprbxrgqseven +3rklddqfnczjfhjmkrgrkslxninesix +9jpcvnlvb3lzqzkvlnqsseven +8ngm64zxplgcdxzdzgfqmtworprmndddr +fivefzhdggmfslthreejmsrq8dxzdzcxsj1 +75six294xbzhjxd2five +56746 +jjxxqclf6eightfive7 +fiveeight9eight +npdgsll2twoxfzq +66fiveninerrbgrshthree9 +nine124nkcsltwoqdlvr +eight4vlsddsjxqthreep8xd84 +mqsbzgsszonexlhljdhdt9kjvdvbmqc +shpxspqrck441twoxjhgthz3fournjtxzgbs +2threegtqmddnine9two +rbdvrngvrjsllkrc542 +p6dckscjkhzfqvc +qblzhpspf4glsrbxm923six +4mfbjznone5svkgvsr47dvtbltlmns1eightwob +5sixsix1twofivexjn8 +5fivefournine4 +gzhzlbkzrlsix5seven3tm +eightpgqrhfqsix41slrs6three +five3dtfzfour +6813nine +3sevenrnhznczgb +mmcgrkjhbsevensevenvrhclthree2 +pfourthree9ninenine +9fbxvvtbzkttwoftv7 +mmthree94fbm +1vsblnklmm2zqmntkp +oneninefivenineone2threeeight +4sevenxzjfxbfdzgfgvjgjdscninetwo4 +64sixfrmtmjoneightt +gzzlqqjsevenone5 +1twoxpcqcvgmhbcm8thlrzmplqpkrbjrqr +jgjqqn291foursevenonefnrdhxt +3bvznvqd8oneeightzchdjvj +ntqtg1 +hsqkbfnxcbsixmvfhxrvxrvnineseven4 +bkztqhhbdzr1sevenonenine1 +v79zpdqfive +tqtwonesixlhhnvf77one1 +2twofour +eight89seven +7six6fmzlrttxstdrg +seventhreecbldkqd89threesevenpplfv +7hmhxpg +threepmvqfc5rktgjl4xvdzmhrninef +7qnlqhtrrk1sevenqfgpkdfc271seven +4gxrqspvg1 +zdgfscbzbdg8rvqseven +eightsevenfour5 +five8five +xprtcnxztmfgtwosnsix5six5 +zpjrhddxfzhdm7pzhxnzsp2six772 +43five92sixfivefour +6kjknjjrjkdfive5sixsevennjone4twonexr +11sevenhvsrb5fourhzxrmgfsl5six +2kbtkmsdfkdzmfplone +68onesevenone7one1 +one36eight +89srlblvkzrjone1 +7threekmzvhxpsdc1 +3648pmjmj4 +fivetwothree8eightonev7x +jlkvd1tgjvdqv48three5 +tvtwone1rhcbkfcj82eighttwofive63 +rkpvjgsfmhbvd7nckshnmzknine +8md7xh8bvsdmhjdxq +threejzrnnfczgzdmcchv5hv4eight +8lqnnnpmfourkndkf926 +651jfltzffxh +onehzk5foursix5 +three7sixfivefive5twonine +four3fiveonef57 +5seven5pbqmzzkqsp +none8five +6threefpqx9eightkhmrgqm4 +ndgmck187mjkxccsdhknine +2jtwomvxjnnpmcseven +bdfnkbhbbfvztpseven6kgknpxmxdfoureight8 +cxtwoskgklsqkdpfive8twohq +5seven67two8dlzmttpdh +cdkzhtk2fvmdtphsxk +threepqcgj8dkfgjp +56tgggrrgdnveightwolc +ninezsix1rnpponedpkqrpdthree +vmgtq3six9 +nhbjgxsixsrrftdt3fivedcdqqq +6fivevqxphgvrflbvljlone +ninexbjtwothree4 +heightwocjpppfive3vlcpc2bt +tbtxlftsnsnknine5q2 +fivemfqlxlpgbpjgnvpfthreefivejzcpkone2 +5dmzkpmpghsixthreenine4 +two9seventqzb578kmfrvlj +six855three +2kddfgninezgsonedptb +1cbbtg1kffourmjxbnvfgjfiveonemgbjtmd +5threec5nine +pvgd5sf7three1lnrfive +83mtfjsrln6 +khtglxc3 +qckdfjbz289nbhnthreehljqfklhmjvrgxt +5kmslxsixsix72 +jlcfmqh5nine +454fournine +jgbfzxdsfpcjpsdlhs5gbsnjxhsfivesix +scxsgsevenseven6fdkcpzm +cbznsevenddvdql431 +fivefourpj871 +xoneighttwo5css4 +sixsevenone49 +xpvktkbdzc6threenine7nine6cnxsdeight +6nlsg8zczsblcppjmbzlnthree3 +jlhzvzskseighttwo1twofivefournqzeight +smmsszqpv653sixsdp5onefour +8nhgxc +cbskddhjq1fourfourj +vqnjgcml5vvggqqlhvdtwonetg +4gdhf1bxrhlnslpnglcx7rhvgnhzjvstwo3 +8fourfive9fivenine4one9 +5xbggkdbkddmfknsxpv +9fivekkttcpntr +cvltwo4 +1four62 +9ninevc +nmfrttms6czdhrdchfkntonetwogc3 +8dfbqlpz9 +fivesixsix595nine4 +6mmpks71nine +ndhdkddjchhseventwo33fv8q +ninerbnhsxkninemdthft1seventwonvgdcgt +twosixbmthh3srhdtnljqlqsbxssnsix +seven22ninedplffive +xpsh1twoqmhkqqsjz +8vrxzhkq +5ninegr +five9nqcmxngktwothree62threethree +qffhltbnineseven9reight +threerqddxgmjnj2 +seveneightqxxgmrzxvhdnine2seventwomtkdmjbkfh +9vppxpsnpdfourdmtqtbm2hpgqlgr +seventhreeczjngnklxg3nsfqzqqeighthcggbk +fflnhnnzncdnh9twoqhx +fjpqseven5noneseven5nined +kdnhflninenine2eightfivemknllfgqspbcrjklx +jmgfqhchzmdfnpthhhcc291shhdqp +5bphvpcxvdf2five9nine6four +9gfpnzjkmlb76xreight9threeqvjxpssvrs +4hpsix6five1ptrdlkfmgr34 +1sixnkvfkvdfjqtwo36eightjnfz +bzstgfhrmmfourseven6xnfvonegzc +fivesix426vgzshhklnknbclnbbpm +k5threetrkghrbcn +13nine +1vlrvlxrsrznlpf +9tgzzddgr1b2 +6sevenrzvcqzsckkqbtsevensevenninehbmlxbzzlf +1991vkjhdp +9jkhnrjjv +6seven47sstqkbthreefour9bmkfbxrzp +seveneightnprhzf61725 +oneone7eight7cpll67 +8eight7one +23bthc337qxhmfbgsix1 +9r61vtgqklone +oneplh6 +four9kfmzbgxlhlxxjf +mhk95 +csdfsix71seventhreesevenfour +sqhrc39 +6three2 +four11sixtwofmvgjvseven1five +four4ninefourkmz2 +mqm5seven3five +sevennine63sixvtwo +81rrvgzzrkzmgsgffvgxlrfbmqxczhtl5tvj +vq8qmg7geight62 +1twoqmmfcseven4six734 +9ghstzndfnmzbtdscl +88twosix +8five5eightworh +ddqdflzbhr68mrdc9 +2threefdb77 +7nine4rbfknbtnsvljnqdtz47 +xrfdfcrtqssx79dvhzls68 +cvqjp6fxkdx9qvsjqptvs +hbzjllr1 +1985onezp2nine +6sixqk52lpftrt +zfqqj8 +c4rljszsspxnnvjl1two +78phbjhkmjltcrxqdblfthreeeightvndtwosksxsxccqz +453gnjntwosevensixfourtwo +2fpnkqlzvmlbbkfxmqgrgv3tbtrkmprx +ffive5f3two +2grzqfmnrld +twofiverd76566csz +eight4zftjjzrkx +onefour8nvrxkqzrfthree3hvzk +fmzqklgfh76lcpjxlvrmgfqpnine8 +nine9xjvvxdvksqrqlhqvrbjvx1 +vlfcpfvl8msxhnftleightwop +846ninethreetwo6two2 +4mjbcckzrhtwo +blsn3onesixfour8 +14two +five3fivesbhfour +onevpqdqds5eight +pcvcsnhv861oneeightfoursix6 +csix7vjllblmgjg +mmn4threesix5vxdsf +v1vx4fivefive4fivevjfjvkf +53tsbldc9skgcshbvxdd +1595bxscggsspvjnbxx37six +seven883 +35sixone4lbzcbgk +tlmvbhjnkknz3nineltztzpclxsixzjnbfvseventwo +rccrkvsvxjbchfive933 +5shkktwokfkkmrxzsssix +five93three +8six44snhpssteightwomjv +nine1nrrjrvjfml4dcklljns +pclkcskcp428199 +fivepjvbtstwojshbgxmdr24eightsix +6eight4 +mjjghhcqrttcjrzhjjrc2five +xkhxgsqjstsevenfour4 +3one5gvmhcbkkdd6 +v3nine9threepfphnkthree6three +ml8twoxnzgqjx1rxbpjnonezrp +one8dtxklgmlnbqhpxl4 +1foureight9fourkmp9 +6vzzdgtfourxtzglhxzvcs +rg4onejhpgsfgpdql +sqpeight488four7svb +63five +39khkbdllxv +bdnjhtcqrxrnnjflfrx5366ninesix +tworfrqzgl85twotwoeight5 +jxeightwo8ttdxhc6xqphg9ntmrtrmxfnjb9 +933rsixeightzbkqkb +1onesix4onefour6d +three6vxnhgxbdxxmdmmggmnxtwocrvftworpsdrrkx +5nineeightninezvf +5jfour +zftjzrfjz8 +8four5nine84mpcktbm +vgg6five5pr8 +3sixtwotwo7ppfsbfppbkmjtlktrx +sixnhcl6bxjxdmgt +pdqfvzgsps9eightj +sixfive87hjksxxbgz1prvfqnnsfmfive +tztgzrnineseventjqhxn3 +twoeight3zthree +nczc3two +jdklbdr4 +j93mnmsixt1 +2fivenine2two65xhcjfnddbqlbd +six48zsklgprrvklt319 +6seven1threephh2bldxvrlln +88threeone +hqktgxxtwonine2 +14fourtghmvcbbnkxkhrvncskgthqqfkgpbrln +threen7rnk5zgjfvtlcs +nine87two56 +859 +six8q7twohnrphb +93oneninethree4 +one7nbzmqdxmj5qfxzcmxfkx +3two2two96ninecnkbt9 +fvcqktlf8two +six4nine4fiveqjthree +91qgvlq6eight3twofive +79sevenfivetcmcsrvvlsl +6bnssix +threefoursix8eight2fivehpp +tlxmqclgdchq8 +threefourthreelbd15fiveknzhg +ktqk68czbjrbkrlnmg3 +oneonerptgcnqzt6fpthmjhgxc8 +rcbfpqhxgjfgfgjcm3 +bxbbqcvvlfivefiversxqpmcb87r7 +two1eight +96sevencktptc9fmnthrdthree +fivehkzxl9five +twosevengsblkmgfzqndznine2seven +two58rlnjdqninetwo +5fiveonesxhbkcjmctwosix +seventhree8952bpqccspldk +8fourpfcvrvc1one +bpbtcnzk27ninemltwo +five2tkqfivethree88ggmpg9 +seven6seventhreemfmnmmbsn +three61xrfghoned9eight +mcffvkprk1one +hvkxcdqcthreetqcr3threeseven +8nmbnhbdseven +bdzc8eight +bzp292one78rthree +ninexsixone71zdnqlcxrphnnbxsmpc +ninempgdsbbdr7 +8eight2367 +15113onelhgvmp8 +8f7gpjllpllptonecfhhpqvcr +ztjj6nine1xsltr4 +nine27gkkjnkcqzt +9gr28eightthblghdkf9lcs +sevenbbjnprlqh1tphfbhbgvlsix33fournine +3sevenfmccnzqxfsfnctfrfngtone +six9xcvlflj +9fqcz1 +one63one3kpnthgscdmtjprseven6 +tlrkvjcdx7txkzrvzcjcvvljfcljc +rfrsfive2ctdmdnqnpfzvvseven +1trdgtvl648frnstf +bxkqchjmphmbnjrkrxxcntpxjnine3sixnkffxsb +84sxd +397lfjmzbp +sixvqjthree2szblfstz +29six833 +bnfnnine8nvjjprkmfourfourfour1 +gb93b98cxblqxskm +3zmggzvlvscbkblhmj4zsevencxgjxsbsr +smf1 +zghrszzcvb5rtnhzktts4 +265qvrzllrctoneshgcbdsbeight +2eightbjvlsixmseveneight +tqfrgkqzbtxqcbxvjzgtp1four +pmrrnmtt1kcf8two +49bnp1tmcglrtpt +4three2ggmbzgqltsqzzjjn +six7frvkdsxdktwo +7cjsnbps7bgqzc +oneoneeight8xbfnnldvpdv +568 +6rhxfbn +nine5nine9fivekftqqgpttptrfstwonerm +three984 +eight99fourmflfdnxvbbmhqfgqkzhkffvmkjxjtngjb +fivefivetwo28zdjmpjccknine +5jjs5vpjzfznrngeight4 +five8one2xllhvb6six +threeninelnfkjrz14 +mhmqpq3hncgqgm43threefive +tjtcrbklrbzvnc4 +37twofourtwothreefour +htwone2threetwo3xtkgk72 +three9btgdgrpdvxkkb1gck1nine +qgnd4sevenone9one4 +lcstxnqmghgqzszkhnbf7threenine +five8four51ddl613 +3vslhppr +tworkcgshlckqjtxpkgcgbgppq6hdvshlntq35 +1eightfiveg5 +five7ztflnine4two +39two +tgone47pvb +37glxx23nhlmxvmvtwo2 +eightsix86twofour +46gznzktfqhlbsqz +171rldrjxcvbsfqmmzcdrnqhjphjqgktwo +6twob3xpfvfdxv79kqqcgljd +6three8hpjtvmvmjxkkmlvtwo +zdeightwomgvbfourfj6khtbsgttnsixeightstbnjmq6 +fhdcqdskf2 +mjssnpxchsclkhlh1threetwoxrbbxkcpkgsbxdxtxxbg +1jxzvllkb71vxxpkmqtvs +three74sixhcthreemgtbzsrh8 +sixtthfskgnine2three9seven52 +nhqzkththreezzsj8four +54fourtklcqcsltgvgqone +four7eightwoq +k3492scxsbbngtwofourtwo +two3ttwor +8snlnfbczd78sevenchzjdphrskjngfkseight +four1vxpvqk15ttcfkt +4twoqql +fhzj4lsvjg +7hstphfour4jsbcndd +7eight85qmjsixseven +1three6two +fivesevendxznmf9 +two54hkv6eight +tlkthdcfldvtzlnr7551 +168qtpcr +fourjlsmgtlvsevennine44hjcksrdfive9 +5cxtbmsn +2twolmtprmjhgndnkfive8qzrdfive +2vpstbjqlxgtpqkd +4dmcc35525one +486xgkdoneffvrleightnine +six1onefivetwo +b144lvmzmxfgntpjhzrk96 +gkgkgc7cmtghq6gbx5 +three87fiveeight33six +1hpkjqvz363vvzksonelfctrztjctthree +pfqdlvkrs9nfpmtnineone2three2five +48onetwovrnbz1two14 +nine5bgvpnjbltfiveonesixfive +nine4pqknine96spqdb37 +mfgcngxqxb41 +262sevensgfjjmdczrl +qzmthreetvjdxnine1gpjsmxtth5 +ninethreeplzkztkzlk1qhjvl4 +oneeightnine3 +onetk5 +fthkbqqfhrpkprhqmssix43xcgdzhtrf +twobhbtvtwo1three +ftbdrfnffzkllk59vc +6ncvrsm +7ftcmjbdmx +12fdnnnqvrrd3 +eight3fqpqlhfvbrqlhhvpdonedzlfive +fourktscmbltflone92fbcrpqhsevenhnpccrhb3 +qbtz5mdksqshdqxft96dvsix +tfpfour75dtgjjmzgjsgjbqdkpd +pxjvfivevhjbmqz4 +tknhlnldjm8five5bqbhzbsix +45zqht +3jrsvctdzpjjrbxznf25klxbnvhpxskthree +foursevenskzzthntbfivefive5 +eight84jtllflx2five8mqjnnl +5xxkcbgx6952qpzgpmczsc +five3mpqdccdmone +kninezsmvpjfhdeightbcnctnf8twosixone +34lpqxkcfjvsixshpnsixgrm9 +glhtgtsq4threetwo3 +eightjbtpnhvhxk46sevencfklxxvdvveightldqqtdtk +fsdfhthreefivesixrkdrgk1thjlfflx +ninekxr6djghngtqninefivethree +3qszkcdvcdl +9sevenxzcskrpgfiveninevcdmkpqqpp222 +jmgt6vftshlq1 +4mnmtbvdznmpmpkrp +94nine972 +rzthreebsjvthreenxqm2 +dxhrstvj344seven +1eightfivedtsstwojbxpnhjnzrgx9three +jlkt3 +fivethree7rfour1fournine +rzggmhlvfivesxzfour363 +4npxrvmxmmc7qjbcrhzsix5lbvkjpp3 +eight7ninefivernpv4cddqhtvkb5 +5threesevensixonesjvxjp3 +5tppjjgj4five +boneightthree92nine5tjppmvhtrfive +threettgpkqcvjzdbjgzk9four +6nzllfrrqkbgseven4nkgdddzbnhr +czjbvrqkone3 +msffqxbxc4294 +one83dxstl7 +32ghhrdt5 +eightsix27two851 +1pmkltwozrx295 +j5982 +81pspmvbbjninetxvpg +six4pprdn4twozpqndgdninefour +3hfthcgqq8682fivefcrfxxgd +nineqtxeighttnine6dttrznddl +htktrcx6gqv5 +txsixsnls1 +52eight +76fivefour9 +eight8tjtc +four3onejlqvgl11436 +dlpdv36 +7foursvdjchltr7qjsj +pknqzgvv3qsltsixfoursevenzggprjvz +3eightfive8one2two +z2eightwokcx +2sixnlhfbfsfeightseven +884qmtqcdcrd4 +keightnine9lpmspq7ninefour +43eight4five7 +twofourfourfourtjfmflt7hcxfpf12 +sevensjpbqjfnqtgcjtktfjhrdv5cr +6ztdzvcsqm +86xsdx +eighthmfgbvsixxcd35zfblslpthree +seven8twoeightpnzrsqlcv +fivezmbqpxhfnnmvbsv61seven63 +5vvddrt1onemvmdsvvfive +7sixpfblcglgj51 +s29 +qtdbb4oneone1onethreesevenseven +drj7six7 +6cfhssixnnjgcxgnmssevenmbfzxps +xbqdclktfrmlq5eight294zvtqhszfmtzd +8rnrcpphkrmfnc +seven77 +9gntctbb +tjgvxtbcn55mcjhmkgzkb +fiveseven9dfllnqdntjonemdztmclc3five1 +83zxfive +87tjnbrxnhzpnthxpnxgczmlghjppfgghzsixfour +6rfivetwonerhn +3cnzlm9eightlqgtjppxj +onefrttlfjthreefive3eight7brmcdrzdz +threeczbzscthreefive551 +2433sxdfjzshrfdpgseight +92gfsjbjdbd9bhsqjpx3nkdpjxs +71foursevenone +6ninedlf6ldnxdzhdtwoseven +fivegcpj6 +xssdl7 +3kcnqqhc9 +sfsrtwosrpjlhbcng6 +mvgeightwotbnzgrrc2tz22bpv1eightfour +94msix2 +tdzkqnbdrmrxfpm7sevenfivekqmhqldjfour2six +sixthree9three +1953seventhreenv5 +2onemhgmxdktf +5fiveoneseven8 +frfvnqxtmthreeeight4 +rphdqh24eightcpqxfjqqrchbtwo7 +76fivebjmcnfrnvpfour +8nine6mrxvppgvjsevenlhtrtnsxmzdnkhhjfcnfd6 +hfmjnine8 +one3rvbjqtfivecc +five6fbfkpdvvpfjq3kdbvhtrkvgqz +two2sevennined7 +five8fourseven398 +sixqccsqhgvhd3k1five +4fgthreesix +4xqgqfxltzx28jrfpqdmbtwo +three35twozhgkpltmvbfsdzkfpbrkq +zxcdrkhd8onepcmtkfmtkrphbhcfivetqhxrnttwo6 +six36rsvpjcj +9fiveqqdklbkonejpvxxteighthvthdsb +six32 +five83rthcrgdjqxsevenfive3 +ninerdrthxkhnz7hlgllpkgjc +jmzsq3two +seven9kmcmbvztgsseven7foursixfourseven +xpgtcr5hxgjgdxrz +rvgdt1b3sggthcldlsevenseventhree +seveneight5fbljmnfsdqc7sph5 +onetwo1nine8jpgthree9 +6ninekfqhgrtplninefive8 +fxsmdhnjgx3ngqlsjtjnq4vqcrmgfqcnffnvdgt5tmddtbhx +z49 +5eightone +6fivehkv8xtgthreeninesix +hshtfdbf82 +bgvonesevenrdtbhsl6zqxn13 +hnlgrrsmhskmxbmxnineseven55 +kpeightwothreezmdvm35onefiveseven +threefourskjcsmhjr32 +154nine8nineone9 +sixtwo77nfgncfzhbcbthree +dnxddftf7qxnxt +six2qlkmkgsfgdnch35hfqpcbvk +145 +xtqpx8nlzqhmbfpjcqqz9sevenone +kqspr8gbqfsvnttcfnfhjdncteightj4eight +bhrmk5fxdtbqbrzv +eight2prrttwo3five7nine +ninefivenrldsh1smcpzvdgmtzhbone +42dplrfkksn +psixtwoz5 +nvxmgsevennine95eight5 +five2onebxjtkkkzddcxfbpg +87ninebcsmzqjqhrfivevd6 +1eightclgrldksdkzt7 +136tgxrm +smzcxqsspl2hc6eightsixfour4 +51lpvxvzvjpdt72 +5rflgvvkrqlsninefivefoursevenseven +5eightssfq +qrvlvn46threegvcsqnpbbq28mvtvpsmfch +sevensevenfrk7threensxmfn +36fiveeightsixseventhreefour9 +lvxfour4three4q +sixlnrbbcvzdztwo3tj +eightclvcgtcrpmbstpeightmnine7 +2five4five6sevenvhmhk3nine +rjone4btcbrsix +621fiveoneightpt +hlv815fourtfvkr6 +two4657 +one1zninertmjxntmkdgrdsixthree +7one83nqxqdppcsxmlrcdone5 +dlctxttzvz6fiveseventwo96km +8xfkfkbp +79 +eight1three +11rrnrm4vfqjfkmfleights +9xglzqljbqhlseven +8lll2btggdnfsjteight +ddtwonekgrhnsffd8rdlqjmzfv599 +two2sixhdvgjz7three +7flfpmnrl1mhcgzblfourbsvftjkgbg +5sevenzstvcgdvk59nine1vn3 +kpkdqrp3two62six +two2nmpzfour8 +b2fivenine67 +ffgf1pbztdtwo47nzdxrcz +8two4s +tztwone5three +3lzbzqkgkh3four +18twonezps +fivefour4rjnsevenslkqltcdpznmfprnbzbztfvnseven +hmhlkcg6zp +3zcrdv16four +hnnlsknrjk4one9onezcfrx2cddnrbtq +4xbkl +6jdkxcvmx +4four1hb5tgfrntttjszgdhdq +vttlslpjtwo7fourqfzpbrninepr +sevennine5f +bcphcjvp7three +8q9621eight +88tth3 +7gddrxzpsix9jxstksdpkseven +seven3zc72np53eight +txxrlgqm2859 +1sixsevenjpqp +five24seven +6fqjcmngvthreeplxxtrklleight +eightsfpxsix439two4two +2sevennineone +ninexh8four9pdzjpnx +fourninecfzsrmonelcpdnsmhn5nvzp +onecpvhfvxsmnffcxph4 +hbljxvthree5twokxpbbmpnmhtmzbqmnlpnine +threefddbhtseven9qsplgqjkgstwoeightbqchst9 +two5six12 +ninebp962 +1two2eightsixoneightt +nineone1oneninethree9 +sevenone1 +fivegone4three2threefour +plbvtpgvdtwothree1kcnvxndf5 +svkfoureight294 +5nineonenhxfl2prgv7xj +9kjzjtdmcsninesevensmdbsxh +32bbcbggpsdvnjlnm5 +hllsdcxhtqhfkzsixgjb1cnjxzghksllfour +sixkqjkzfxnx6 +4fpmfour4three8 +gzbgcvf523onefivepqsqkqone +8one83 +sixbrcsix8fdhzvxcvchvlhx7ddpbltgxq +4sixhfrdpshdsixlvptxfjcplscxzg8 +fivebrxjceightone7 +twojmbxonefivefourmsqbnzxsgxbbh2 +five5lrzrsv17 +rtsgveightljjrkhskhqkseven6seven1 +74lcrchfoursevensix +49tlnbghzm1 +36nineeight2 +fivecccctcftfourfivetwo41 +foursevenfourmlrcjglthjd9 +94ninetwosixvbqslbxlone +qjjk76 +3six35onesix52 +612dfpgjlgfourfive3fourdmrn +9one2kctccfct +vbsoneightscfiverrvmsrxjcnbvpeight2onekkqhsjtx +742fiveeightnvjjpx4eight +139sixskbgfc2sevennmlsll +2nineztlb6pxgqtreighteight2 +six58bjjhsrxgrheight9 +nrmncthgr4bggpj +1pgjpxjdbhj +four5tjqsv47ninetmpjmmpcgftjmqq +threepnxphfourplcrpjfngjsgdninepv6fzghjjmrvn +756onejrtbpl3 +sixglcb8 +jqcfpvq46xmffour6 +sevenfbhqztmn96eight +2fjlcxsix8d +eight9fourvjjjpninepndvffivenine +mctmpckkjfqmdhgcdng5sfk6bgbg +onethreesevenrdgcqsldlv8jddcfncninetwo +gmkkbtndjlnzhqfeight6sevenggjrlqkzqv7ngtkfdpjr +4tjpqcjjvxndnhrfdllddptwo +lzjzfshq71ndzmpf6ninesixxjgrvqtrp +sevenhxtmvftb38937 +gxnrvjvclckvfkksslzjgf6kvqgpjbtwo +one9sg7jsvgx28threevsmpxtlrc +five4vvvrrmfj +1hkzflszztc45nine29 +36qbhjdxjr +glfmnmdqlfgxrzfsc2vcxmxcvjkrnltjpdsixgsrpgjnrthree7 +jnbgtjcnbvsf7hhmb +three9eightspggt +4f77sevenkrsvzkrlr +ztlrbheightseven6rcsflgpxnvfkrntbsevensbxjgvsb5 +six7nfcsksevenmkxone +zoneightnine3eight5cdgzqfq66one +8threefourkkkhvc68four +fourthreer9eight +dxzxrjptfmttnppfskctvbngmf268eight2 +2onethree +rtwone3seventwo72 +eightninegmfct96seven +4rcjltsng7threebxcsneight +nine54pghqbgrqjgzmjrgeightrzlbghr +nvggfgkzvknfiveeightsixthree43 +4fourjpzglr +83sevenbn9seven9 +mvgxgqvpbgmrcvdsn34 +sfjlninejbckkxlf8seven +three72threebsgtrtb1tmgjbngqxm +jqlx44 +1threexdftqfjcvl +nnkjmmlqvdseveneightkqlmmzzrpfiveonefour8 +9nqjzjjhhps9twonex +lzqxtpvztwo6 +47fiveeight8gnhcgldm2tlpsxfpsb +5one316four +9lzvbtlkzdgzcxrbtlthhqbdvklgkz7nine1 +threehjxknjnthreeseven2one7 +threeninehjbslk13 +sixeightone6pvdkkbvseven3 +gnlszqcmg8twotwo6 +gxttbccg2khzzpkdtonezqsteight3six +vtfjnxjjkmzppsjx9twofour +twoplbfnmkgql5fpfpzndddt +2threeeightjgkfivevcjlmc4onetl +2bzngbghgkdhhgqpgqkonesix1 +2fivenine22 +lhpxstx1mhgpndxlnk +one7ninetwo2fivethree +seven2sevenonenine9 +onezgpeight81ninekzgqsmmtrpqz +681qchvmrdldjs +nzlqbsvteight11nnnbhkdbvp8 +sevenxgqxtjdjpq3 +8ztonetwoeight +9xkmjfourfz +83four6 +m69 +two1blfseven1 +jdmkrkzkjjsdkkdone5 +7six3 +3one27ninethreeninesevenqzfkst +6nineseven9eight3 +one8zfrvtwoshlgvbl5ljrftn +one1165bjcpkpsjfxlnmz6 +72eightwoh +seven1one94eightsqzhnrfbx8z +sixeight2frplhhsxn46two +7gppcfcdl8 +nine94eightkjxpmzvq +nvf8sjqrncflgpdbone3 +68fourlnc +two5ppgttnk +nine28sixzxnhjr +7kdg38 +twol4qmspdsixfiveskjsbrfsxxjpkqdtsmkgpbc +five5nzlcdc45clclzrrkjthreeoneoneightsd +cvmxgrvfddx3rdthreefdqhxlzzb6 +sevenhzxklrz1threebzvgssix8fstqhzn +tfv866fivetlfive +knmzhbvhzfvrbkvsmnl7sixseven +zmbq9 +vqxqnzrpqvtdtmgndhs7eightnqpxcntfmjr +4vzpsdreight337hgvq +jone4ccn8 +nftdkmtmcz4 +nlnineeightmndkqz8nineonenrqm +nrhdxfsqvxcbcghf35eightthreeseven5 diff --git a/Advent-of-Code-2023/aoc-1/main.c b/Advent-of-Code-2023/aoc-1/main.c new file mode 100644 index 0000000..559ddab --- /dev/null +++ b/Advent-of-Code-2023/aoc-1/main.c @@ -0,0 +1,259 @@ +#include <stdio.h> +#include <stdlib.h> +#include <string.h> +#include <ctype.h> +#include <stdbool.h> + +#define QUEUE_CAP 128 +#define CHILDREN_CAP 128 + +#define ARR_SIZE(a) (sizeof(a)/sizeof(*a)) + +// #define FILENAME "sample.txt" +#define FILENAME "input.txt" + +// #define PART1 +#define PART2 + +#define NUMS(X) \ + X(1, 1, 177622) \ + X(2, 2, 177623) \ + X(3, 3, 177624) \ + X(4, 4, 177625) \ + X(5, 5, 177626) \ + X(6, 6, 177627) \ + X(7, 7, 177628) \ + X(8, 8, 177629) \ + X(9, 9, 177630) \ + +#define STRS(X) \ + X(one, 1, 193501607) \ + X(two, 2, 193507359) \ + X(three, 3, 210728981597) \ + X(four, 4, 6385231329) \ + X(five, 5, 6385224815) \ + X(six, 6, 193505817) \ + X(seven, 7, 210727692230) \ + X(eight, 8, 210711216854) \ + X(nine, 9, 6385512047) \ + +#define TO_STR_ARR(s, v, h) #s, + +#define TO_CASE(s, v, h) \ + case h: \ + if(num_str[0] == 0) { \ + num_str[0] = #v[0]; \ + num_str[1] = #v[0]; \ + } else { \ + num_str[1] = #v[0]; \ + } \ + break; + + +// https://www.cse.yorku.ca/~oz/hash.html +unsigned long hash(char *str) +{ + unsigned long hash = 5381; + int c; + + while ((c = *str++)) + hash = ((hash << 5) + hash) + c; + + return hash; +} + +// https://en.wikipedia.org/wiki/Aho%E2%80%93Corasick_algorithm +typedef struct trie_node { + struct trie_node *parent; + struct trie_node *children[CHILDREN_CAP]; + + struct trie_node *suffix; + bool end; +} trie; + +trie *trie_init(char **dictionary, size_t nwords); +void trie_search(trie *root, char *str, void (*callback)(char *str, size_t len)); +void trie_free(trie *root); +void trie_print(trie *root); + +size_t sum = 0; +char num_str[3] = {0}; + +void handle_match(char *str, size_t len) +{ + char s[len+1]; s[len] = '\0'; + memcpy(s, str, len); + + switch(hash(s)) { + NUMS(TO_CASE) +#ifdef PART2 + STRS(TO_CASE) +#endif + default: + fprintf(stderr, "bad hash: %lu (of str %s)", hash(s), s); + } +} + +int main(void) +{ + char *dictionary[] = { + NUMS(TO_STR_ARR) +#ifdef PART2 + STRS(TO_STR_ARR) +#endif + }; + + trie *root = trie_init(dictionary, ARR_SIZE(dictionary)); + trie_print(root); + + FILE *fp = fopen(FILENAME, "r"); + if(!fp) { + perror("fopen: failed"); + return 1; + } + + char line[256]; + while(fgets(line, sizeof(line), fp)) { + trie_search(root, line, handle_match); + sum += atoi(num_str); + num_str[0] = 0; num_str[1] = 0; + } + + fclose(fp); + + printf("Sum: %ld\n", sum); + + trie_free(root); + return 0; +} + +static trie *trie_find_suffix(trie *node, size_t idx); +static void trie_set_suffix(trie *node, size_t idx); + +static void trie_traverse(trie *parent, void (*callback)(trie *node, size_t idx)); +static void trie_add_pattern(trie *node, char *pattern); + +trie *trie_init(char **patterns, size_t nwords) +{ + trie *root = malloc(sizeof(trie)); + memset(root, 0, sizeof(trie)); + + // generate the basic trie + for(size_t i = 0; i < nwords; i++) { + trie_add_pattern(root, patterns[i]); + } + + // calculate suffix links + trie_traverse(root, trie_set_suffix); + + return root; +} + +void trie_search(trie *root, char *str, void (*callback)(char *str, size_t len)) +{ + trie *node = root; + for(size_t i = 0; i < strlen(str)+1; i++) { + if(node->children[(size_t)str[i]] != NULL) { + node = node->children[(size_t)str[i]]; + continue; + } + + if(node->end) { + int len = 0; trie *tmp = node; + while(tmp->parent != NULL) { + tmp = tmp->parent; + len++; + } + callback(&str[i-len], len); + } + + if(node->suffix == NULL) continue; + + node = node->suffix; + i--; continue; + } +} + +void trie_free(trie *root) +{ + for(int i = 0; i < CHILDREN_CAP; i++) + if(root->children[i] != NULL) { + trie_free(root->children[i]); + } + + free(root); +} + +static void trie_print_child(trie *root, trie *node, size_t depth) +{ + for(int i = 0; i < CHILDREN_CAP; i++) { + if(node->children[i] != NULL) { + for(size_t i = 0; i < depth; i++) printf(" "); + printf("%c (%p) -> (%p) %s\n", i, (void *)node->children[i], + (void *)((node->children[i]->suffix == root) ? + 0 : node->children[i]->suffix), + (node->children[i]->end ? "END" : "")); + trie_print_child(root, node->children[i], depth+2); + } + } +} + +void trie_print(trie *root) +{ + printf("ROOT (%p)\n", (void *)root); + trie_print_child(root, root, 2); +} + +static trie *trie_find_suffix(trie *node, size_t idx) +{ + if(node->suffix == NULL) return node; // root + + if(node->suffix->children[idx] != NULL) { + return node->suffix->children[idx]; + } else { + return trie_find_suffix(node->suffix, idx); + } +} + + +static void trie_set_suffix(trie *node, size_t idx) +{ + node->suffix = trie_find_suffix(node->parent, idx); +} + +static void trie_traverse(trie *root, void (*callback)(trie *node, size_t idx)) +{ + // breadth-first traversal + + trie *queue[QUEUE_CAP] = {0}; + size_t queue_start = 0, queue_end = 0; + + queue[queue_end++] = root; + + while(queue_start != queue_end) { + trie *parent = queue[queue_start++ % QUEUE_CAP]; + for(size_t i = 0; i < CHILDREN_CAP; i++) + if(parent->children[i] != NULL) { + callback(parent->children[i], i); + queue[queue_end++ % QUEUE_CAP] = parent->children[i]; + } + } +} + +static void trie_add_pattern(trie *node, char *pattern) +{ + if(pattern[0] == '\0') { + node->end = true; + return; + } + + if(node->children[(size_t)pattern[0]] == NULL) { + trie *child = malloc(sizeof(trie)); + memset(child, 0, sizeof(trie)); + + child->parent = node; + node->children[(size_t)pattern[0]] = child; + } + + trie_add_pattern(node->children[(size_t)pattern[0]], &pattern[1]); +} diff --git a/Advent-of-Code-2023/aoc-1/sample.txt b/Advent-of-Code-2023/aoc-1/sample.txt new file mode 100644 index 0000000..41aa89c --- /dev/null +++ b/Advent-of-Code-2023/aoc-1/sample.txt @@ -0,0 +1,7 @@ +two1nine +eightwothree +abcone2threexyz +xtwone3four +4nineeightseven2 +zoneight234 +7pqrstsixteen |