aboutsummaryrefslogtreecommitdiffstats
path: root/year2021/day6/consteval.cpp
diff options
context:
space:
mode:
authorClyne Sullivan <clyne@bitgloo.com>2022-11-30 19:55:31 -0500
committerClyne Sullivan <clyne@bitgloo.com>2022-11-30 19:55:31 -0500
commit8d43e37df99f280377bed90284d6ac2428334804 (patch)
tree3a5042c9af29da52b4bac38fd78b3ccde77a1dbc /year2021/day6/consteval.cpp
parent66ed0b9d27850dc653abc8baa75884f3de311bfa (diff)
move 2021 days to folder; update README
Diffstat (limited to 'year2021/day6/consteval.cpp')
-rw-r--r--year2021/day6/consteval.cpp32
1 files changed, 32 insertions, 0 deletions
diff --git a/year2021/day6/consteval.cpp b/year2021/day6/consteval.cpp
new file mode 100644
index 0000000..f46da89
--- /dev/null
+++ b/year2021/day6/consteval.cpp
@@ -0,0 +1,32 @@
+#include <algorithm>
+#include <cstdint>
+#include <numeric>
+#include <iostream>
+
+consteval auto countFish(unsigned int day)
+{
+ unsigned char input[] = {
+ //3,4,3,1,2
+#include "in"
+ };
+
+ uint64_t counts[9];
+ std::fill(counts, counts + 9, 0);
+ for (int i = 0; i < sizeof(input); ++i)
+ ++counts[input[i]];
+
+ for (int i = 0; i < day; ++i) {
+ std::rotate(counts, counts + 1, counts + 9);
+ counts[6] += counts[8];
+ }
+
+ return std::accumulate(counts, counts + 9, 0ull);
+}
+
+int main()
+{
+ std::cout << "80: " << countFish(80) << std::endl;
+ std::cout << "256: " << countFish(256) << std::endl;
+ return 0;
+}
+