From a3f94409df447a76961f3f48f975d64d08573934 Mon Sep 17 00:00:00 2001 From: Viacheslav Slinko Date: Sun, 22 Dec 2024 11:08:03 +0300 Subject: [PATCH] day22 --- qwe.py | 23 +++++++++++++++++++++++ src/day22.rs | 29 ++++++++++------------------- 2 files changed, 33 insertions(+), 19 deletions(-) create mode 100644 qwe.py diff --git a/qwe.py b/qwe.py new file mode 100644 index 0000000..6f1be4f --- /dev/null +++ b/qwe.py @@ -0,0 +1,23 @@ +variants = [] + +am = 1 +mm = 19 +bm = am * mm +cm = bm * mm +dm = cm * mm + +print(am, bm, cm, dm) + +def hash_fn(a, b, c, d): + return (a+9) + (b+9) * 19 + (c+9) * 361 + (d+9) * 6859 + +for a in range(-9, 10): + for b in range(-9, 10): + for c in range(-9, 10): + for d in range(-9, 10): + variants.append(hash_fn(a, b, c, d)) + +print(len(variants)) +print(len(set(variants))) +print(min(variants)) +print(max(variants)) diff --git a/src/day22.rs b/src/day22.rs index 2b454a7..f530fd3 100644 --- a/src/day22.rs +++ b/src/day22.rs @@ -1,5 +1,3 @@ -use rustc_hash::{FxBuildHasher, FxHashMap, FxHashSet}; - fn mix(a: i64, b: i64) -> i64 { if a == 42 && b == 15 { return 37; @@ -41,29 +39,22 @@ pub fn part1(input: &str) -> i64 { .sum() } -fn seq_hash(a: i64, b: i64, c: i64, d: i64) -> i64 { - a + b * 100 + c * 10000 + d * 1000000 +fn seq_hash(a: i64, b: i64, c: i64, d: i64) -> usize { + ((a + 9) + (b + 9) * 19 + (c + 9) * 361 + (d + 9) * 6859) as usize } pub fn part2(input: &str) -> i64 { - let mut results_map: FxHashMap = - FxHashMap::with_capacity_and_hasher(50000, FxBuildHasher::default()); - let mut already_done: FxHashSet = - FxHashSet::with_capacity_and_hasher(2000, FxBuildHasher::default()); - + let mut results_map: [i64; 130321] = [0; 130321]; + let mut already_done: [bool; 130321] = [false; 130321]; let mut diff_seq: [i64; 4] = [0, 0, 0, 0]; macro_rules! remember_seq { ($diff_seq:expr, $new_price:expr) => { - let seq = seq_hash($diff_seq[0], $diff_seq[1], $diff_seq[2], $diff_seq[3]); - - if !already_done.contains(&seq) { - already_done.insert(seq); + let hash = seq_hash($diff_seq[0], $diff_seq[1], $diff_seq[2], $diff_seq[3]); - results_map - .entry(seq) - .and_modify(|e| *e += $new_price) - .or_insert($new_price); + if !already_done[hash] { + already_done[hash] = true; + results_map[hash] += $new_price; } }; } @@ -105,10 +96,10 @@ pub fn part2(input: &str) -> i64 { }); } - already_done.clear(); + already_done.fill(false); } - *results_map.values().max().unwrap() + *results_map.iter().max().unwrap() } #[cfg(test)]