aboutsummaryrefslogtreecommitdiff
path: root/advent-of-code/2022/06/1.c
diff options
context:
space:
mode:
authorMistivia <i@mistivia.com>2024-01-27 14:28:51 +0800
committerMistivia <i@mistivia.com>2024-01-27 14:28:51 +0800
commit087a111b3417cbda03a3453b3d16dd4d1cf54a9e (patch)
tree000a15054865c3fb974970238568bb1d81a3f29e /advent-of-code/2022/06/1.c
parent203658f4a5b8649d0142ab8ff6440eb0eefa48e9 (diff)
add aoc 2022
Diffstat (limited to 'advent-of-code/2022/06/1.c')
-rw-r--r--advent-of-code/2022/06/1.c26
1 files changed, 26 insertions, 0 deletions
diff --git a/advent-of-code/2022/06/1.c b/advent-of-code/2022/06/1.c
new file mode 100644
index 0000000..30a64d9
--- /dev/null
+++ b/advent-of-code/2022/06/1.c
@@ -0,0 +1,26 @@
+#include <stdio.h>
+#include <stdbool.h>
+
+bool succ(char *buf) {
+ bool table[26] = {0};
+ for (int i = 0; i < 4; i++) {
+ if(!table[buf[i] - 'a']) table[buf[i] - 'a'] = true;
+ else return false;
+ }
+ return true;
+}
+
+int main() {
+ FILE *fp = fopen("input", "r");
+ char buf[4] = {0};
+ int i = 0;
+ int c;
+ while ((c = fgetc(fp)) != EOF) {
+ if (c < 'a' || c > 'z') continue;
+ buf[i % 4] = c;
+ if (i >= 4 && succ(buf)) break;
+ i++;
+ }
+ printf("%d\n", i+1);
+ return 0;
+}