aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMarvin Borner2021-12-09 12:47:13 +0100
committerMarvin Borner2021-12-09 12:47:13 +0100
commit9eabd251029d1da7f2909af0520f229dd74be3ea (patch)
tree734cefb377346adb468ee2b3f42afbcc6131d141
parent35bd5c59da5aa1869f433218fc37dbd22b8b0793 (diff)
hehe
-rw-r--r--2021/09/Makefile19
-rw-r--r--2021/09/input100
-rw-r--r--2021/09/solve.c80
3 files changed, 199 insertions, 0 deletions
diff --git a/2021/09/Makefile b/2021/09/Makefile
new file mode 100644
index 0000000..da646cc
--- /dev/null
+++ b/2021/09/Makefile
@@ -0,0 +1,19 @@
+DEBUG = -Wno-error -Og -g -s -fsanitize=undefined -fsanitize=address -fstack-protector-all
+CFLAGS = -std=gnu99 -Wall -Wextra -Werror -Wshadow -Wpointer-arith -Wwrite-strings -Wredundant-decls -Wnested-externs -Wformat=2 -Wmissing-declarations -Wstrict-prototypes -Wmissing-prototypes -Wcast-qual -Wswitch-default -Wswitch-enum -Wunreachable-code -Wundef -Wold-style-definition -Wvla -Ofast
+
+# Not the best makefile but idc
+
+debug:
+ @gcc $(CFLAGS) $(DEBUG) solve.c -o solve.o -L/usr/lib -lcrypto
+
+build:
+ @gcc $(CFLAGS) solve.c -o solve.o -L/usr/lib -lcrypto
+
+clean:
+ @rm -f *.o
+
+run: debug
+ @./solve.o
+
+time: build
+ @./solve.o
diff --git a/2021/09/input b/2021/09/input
new file mode 100644
index 0000000..f11825a
--- /dev/null
+++ b/2021/09/input
@@ -0,0 +1,100 @@
+3235678976543234569109899875456987676387679999878953234987656895457998743212347892123999912987632489
+2124899989932145698998789994329876545235567899768995349898546789346987654423656789339889899986541678
+1012567897898756797987678989212985432103458987656789456789435691235998775634987897998776798775430567
+2343489956789987976798899578901299654512578998545899567894326890449899896845898945899655987654321378
+3455697645678999875679965467892398999323456789656798998952018921598799987896789235789544398765435459
+4589789432567987764597654358679497878954578996987987999543459433697689899987892123498732129879646589
+5678994321456976543989543236568986769895989654599876789765569555987578778999989014987653234998789678
+6789875432349897659878943123459875458789996543298765678987678976899434569019878925998754345679898789
+7894987654599798798768932012598766345678997692199854567898789987998923978998767899899987456789989899
+9993298765987689988957899129679953237899989989987623456789898698987899899998756798789896588899878967
+8989109876796569977845678998998767129949876979798544587899954569876786799987546989656799679999865456
+7678912987965498765434567897899643298939965765679656798998768998765125899997639876545678996598754321
+6567894599876329896545878976987654987898954354598787899999879129654014768998549865434568995439863210
+5456789678997547989656789454598767976767976123459898976799989098643123456789998754323456789521994921
+4347998799987656978967894323789879765656891012567999765789899987654354799999876543212368996542989899
+3298949898998799867899965434678998654346789123458998654576789298966455678935987654345679987759878788
+4989534987899987656789879765799998743235679254569876543445679019878766789124598775656799999898765667
+9878921256999876546899989878987879865123789365678989521234695434989899893012349987878898989987654545
+9967892345987655434989999989876565986239895478789998432345696549999989932123457898999947678998943234
+8756793496796542323478999898785454987645996589893987643456789698999878943934578999986434567899932123
+4345789989987641014567896797685323498656789699912397654567999987899867999895689598765323456997821012
+3234699879876532123479965986543212349987899898901469895689109876987656789789791459853212349876543156
+0134589965998743234569534598655304558998910967893456976789999965496544345678992398654101256997643245
+1234567894569854375678976789766412367899321256789569987896789896986432234569989987653212397987656356
+2547678923456975676989997999896567898996432345679678998935698789876531023789877999765323989998975457
+3458789212689876989299989123987878979987593958798989899123987678987632234989765789876439879899876568
+5569896345678987892109878994698989767998989899997898789239899568998544345678954567999949768799987679
+6789965456789998943498767789899694545899878789986787679398798457899765459899543456798798656689998989
+8992986767898969894989345699986543236789765699875656568997656356789876567989212378999659543567899992
+9901299878987656789875234599997654697999873987654343459789543235899989678978934567998943212578923901
+7899988989876545678984123678939765789876542198843212345678910124589998789567895979876432101458939892
+6798767998783234569873234569219896899965431097652101234889321234678999893459976789987943242357898789
+7987657789656123698764675678909987939878592198963213455695432348989876932347997895699894343456789678
+9876546678943234999878786789698998921989989999984323567789543567898765421286789934598789658767893467
+9965436567894549898989897896567899993998767899876544568897654578919976982345690129987678969878912345
+9894325476789698787898999965456789989897656791987675689999879989102989876456789398776579899989423456
+8763212345998789656797897654239999976798745690998786789899998996212399988767891987654456779997678967
+7654323466789899645685679793198898765679659989879897896789987895475498999898910399743234568998789878
+8876434578899998921434998989987679954549798878764998945698976796786987989979521249432123456789892989
+9987545699998987890129897678976567893234987654353459936987895989899896878965434598543234587899921094
+1099786789997876789298786567897789964645898983232345899876764878998795769896545697654355699999992123
+2199899899896765678999543498999899875776789872101236789965743767896543456789676898768456789998989934
+3987989998765434567895432345699912986989899654312345679874232456965432345678987999899567899987679895
+9876378987654323456989541016989993997893998765459569797662101247894321234569998999999698919876567789
+8765459876543212345678952345679889898912999877568678989543212348973210123459899989998789909865434697
+9896567997654101456789763456798768789909899989679789978965343459765421234598768978999897898954323456
+3987678998783216598899874567987654567899769998789898869897654789987532345987659767893956797895412345
+2198789659854427689976985678995453478999878919899987656798765678998743456976745457891045976589101956
+1019894345967838798765696789984322246789989434989998745689977899987654579875432345679134989678999897
+2129943259878545897654987899876510135678998765678986534567898945998775689976543678989245698789989789
+3498899198989656976543498998765421234569999878789198645778999439899976789989774567899876789999877676
+9987788987698767897662349899896544346789789989891099876889789598789997898798765679943989899998764565
+8976547896549878999743456789987675487895679797992987989997678987678989998549978789952199978999543634
+7987436789432989987654589992398789598934589656789976599986569876569878987634599897893298767997432123
+6798545697653498998765678990999897679545678934699954349875498765498767896545987956789987659876541012
+5569658789894567899878799789897998798696799129789897598764349854323458997659876545678998434989752123
+3498767999965678945989895699766569999989894298998789987543212976212356789998987676799129323499843234
+2349879569876789234997964578957346988778995987688678999674309765301235789897698987899997434568974365
+1234989435989892199875453689541239879569789876576567898764312943213376898767539398999876567899765486
+0145895323499953987654312795432498765489678965435456999985429894524567999754321239899987678969876597
+2256789212989879876543201976643987654344567894324345899876998789634789698765210156799998789943987678
+3457894109876989987859349897656996432253456799210236789989897678945797549874321234567899999899998789
+7568943298765799998998998799787897641012345678921234999896789567896965434989939545689949876788999899
+8678954369934678999897687678998999832243658789762349896765689456789876629897898956893235965457999999
+9889876459895799999765458567899998954354567899943498775674578967899997898766757897932101294356789998
+2999987598789899987654323457899987895465678999899987654323789878998798987654646798943912989245679987
+1989998997678989987543212346789896789878789989768999765454789999997669597543434789799899878968798766
+9978999986569678998654343677898785698989899877657898986565678999976543496532323597698798967899999854
+8867898765474567898767654578998674567899998765434587897878989989898932989421014976597677657999878975
+7656569876343569999898767689776543456789679879523456789989999879789891978993429897989556547689969989
+6547434987212345899999878797654312367996567997612346789599899965656789767989598789876443234567898795
+5432129998323456789785989896543201498923489876324457893456789654345698654678987698654321015798997654
+7321098999974567897674599987654432349314567965435678932969898769296987563567897549976572123456789543
+5432987898765678976553678998865543458909689976645679659899999898989995432456789432987654234569899654
+7649876549989989865442345679976754567898990987876789798789999987678986321568897643498765365878978985
+8998765430199998754321256989987866678987891298987899898698789876569854310978998756789876476989767976
+9987654321248999987532347899998978989876789459998923999569656965498765423989989867899989588995456897
+3298765442357897598675456999899989896765678999879212679678949854349876534599878989989997678985345789
+4109877675456789459986587899788998765634789989765424598789799765456988545679767495678998789873276789
+5298988786767894367987898997697989654325699978996876969897678976567997657889654323567899898762177899
+6987699887878985499098999876586478999438798767889989853934569989698998768999767015678976999654567977
+7996567998989876989139798965432367878949899848779998762123493194989879879999899524569345999965678956
+9875456789991989878945697654331456567899995437567899643434789012978767989989998434679999889876789545
+3984345678910198867896989963210123458999876523458998755645678999767856899978987678798788768989897632
+1296456789321997457997979894523236569996543212568979877876799987653345678969998989989678456896999743
+3989587898459876346789868789754347678987954323678965989987894699542126789458999899876543267895989654
+9878999996598754265697754699965498789599875434567894395998913398653234892347898757995432126789878965
+8767898789987662154986543659876789894323987565678943214879901298764345891276789549876574235678969897
+8656797678996543012965432348997898965634598986789432102367892989865456789345678932997865348789556798
+6545689589898784329876541557889967996789679797899543223456999879876869995457799321099876789894346789
+5432123497659895839865432345678959889898797698998674334567896567987878976569899932989987899921256999
+6563234987643976749877565456789545678999896549019775476878923456798989987878979893978598978932349898
+7854599865532397956988987667896734567899975432129896587889212769899690198989458789867439569899998767
+8965987654321298967899998778954323479989876543599987898992101278943591989693245698754523498788897656
+9876998765434349879998999899655212345678987655989998999653234568932989876562134987643212989697789643
+9987899876545656989587899976542103456789198779878999998765356789549979989431023987654109878576679932
+9898943999856767895456789989653214567891019889767899979976487899998768999545124598543298765434567893
+9769432349767878974367895397654323456789326998752398765987599959897656598657234987654998654323478954
+8754321239879999865458943239765464567895445987631259854398910145789543498765345698769876543212356799
+9653210123989439876789432129896875689976556796532349876459321234895432349877456789878987643101234678
diff --git a/2021/09/solve.c b/2021/09/solve.c
new file mode 100644
index 0000000..d4511d4
--- /dev/null
+++ b/2021/09/solve.c
@@ -0,0 +1,80 @@
+#include <stdio.h>
+#include <stdlib.h>
+#include <time.h>
+
+#define COUNT(a) ((int)(sizeof(a) / sizeof 0 [a]))
+
+#define WHOLE \
+ fseek(fp, 0, SEEK_END); \
+ long fsize = ftell(fp); \
+ fseek(fp, 0, SEEK_SET); \
+ char *data = malloc(fsize + 1); \
+ fread(data, 1, fsize, fp); \
+ data[fsize] = 0;
+
+#define X 100
+#define Y 100
+#define MAGIC 0x80
+#define _GET(x, y) data[(y) * (X + 1) + (x)]
+#define GET(x, y) ((_GET(x, y) & ~MAGIC) & 0xff)
+static void solve(FILE *fp)
+{
+ int res = 0;
+
+ WHOLE;
+
+ int basin(int x, int y)
+ {
+ if (x < 0 || x >= X || y < 0 || y >= Y || (_GET(x, y) & MAGIC) || GET(x, y) == '9')
+ return 0;
+ _GET(x, y) |= MAGIC;
+ return basin(x + 1, y) + basin(x - 1, y) + basin(x, y + 1) + basin(x, y - 1) + 1;
+ }
+
+ int basins[3] = { 0 };
+ for (int y = 0; y < Y; y++) {
+ for (int x = 0; x < X; x++) {
+ char a = GET(x, y);
+ if (!((x < 1 || GET(x - 1, y) > a) && (x + 1 >= X || GET(x + 1, y) > a) &&
+ ((y < 1 || GET(x, y - 1) > a) && (y + 1 >= Y || GET(x, y + 1) > a))))
+ continue;
+
+ int b = basin(x, y);
+ for (int i = 0; i < COUNT(basins); i++) {
+ if (b > basins[i]) {
+ for (int j = i; j < COUNT(basins); j++) {
+ if (basins[i] > basins[j]) {
+ basins[j] = basins[i];
+ break;
+ }
+ }
+ basins[i] = b;
+ break;
+ }
+ }
+ res += a - '0' + 1;
+ }
+ }
+ free(data);
+
+ printf("%d\n", res);
+ printf("%d\n", basins[0] * basins[1] * basins[2]);
+}
+
+int main(int argc, char *argv[])
+{
+ (void)argc;
+ (void)argv;
+
+ FILE *fp = fopen("input", "r");
+ if (!fp)
+ exit(EXIT_FAILURE);
+
+ clock_t tic = clock();
+ solve(fp);
+ clock_t toc = clock();
+ printf("TIME: %f seconds\n", (double)(toc - tic) / CLOCKS_PER_SEC);
+
+ fclose(fp);
+ return 0;
+}