cleanup: day 14
This commit is contained in:
parent
aead1786ba
commit
1f4e5be195
@ -1,65 +1,19 @@
|
|||||||
use crate::prelude::*;
|
use crate::prelude::*;
|
||||||
|
|
||||||
pub type I = &'static str;
|
|
||||||
pub type O = usize;
|
pub type O = usize;
|
||||||
|
|
||||||
fn _parse (data: &str) -> I {
|
pub const INPUT: &'static str = "qzyelonm";
|
||||||
Default::default()
|
|
||||||
}
|
|
||||||
|
|
||||||
fn _solve (data: &I) -> O {
|
fn _solve (extra: u32) -> O {
|
||||||
Default::default()
|
|
||||||
}
|
|
||||||
|
|
||||||
fn _silver (data: &I) -> O {
|
|
||||||
let mut candidates: M<char, Vec<usize>> = M::new();
|
let mut candidates: M<char, Vec<usize>> = M::new();
|
||||||
let mut done: Vec<usize> = vec![];
|
let mut done: Vec<usize> = vec![];
|
||||||
|
|
||||||
for i in 0.. {
|
for i in 0.. {
|
||||||
let s = format!("{data}{i}");
|
let s = format!("{INPUT}{i}");
|
||||||
let hash = md5::compute(s);
|
|
||||||
let repr = format!("{:x}", hash);
|
|
||||||
|
|
||||||
let three = repr.chars().tuple_windows().find(|&(a, b, c)| a == b && b == c);
|
|
||||||
|
|
||||||
if let Some((c, _, _)) = three {
|
|
||||||
if !candidates.is_empty() {
|
|
||||||
let five = repr.chars().tuple_windows().find(|&(a, b, c, d, e)| a == b && a == c && a == d && a == e);
|
|
||||||
if let Some((c, _, _, _, _)) = five {
|
|
||||||
if let Some(candidates) = candidates.get_mut(&c) {
|
|
||||||
let pos = candidates.iter().position(|pos| pos + 1000 > i);
|
|
||||||
if let Some(pos) = pos {
|
|
||||||
let drained = candidates.drain(pos..).collect_vec();
|
|
||||||
// println!("{} at: {:?} added to vec: {}", c, drained, repr);
|
|
||||||
|
|
||||||
done.extend(drained);
|
|
||||||
candidates.clear();
|
|
||||||
if done.len() >= 100 { // extra
|
|
||||||
done.sort();
|
|
||||||
return done[63];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
candidates.entry(c).or_default().push(i);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// 15189: too high
|
|
||||||
0
|
|
||||||
}
|
|
||||||
|
|
||||||
fn _gold (data: &I) -> O {
|
|
||||||
let mut candidates: M<char, Vec<usize>> = M::new();
|
|
||||||
let mut done: Vec<usize> = vec![];
|
|
||||||
|
|
||||||
for i in 0.. {
|
|
||||||
let s = format!("{data}{i}");
|
|
||||||
let mut hash = md5::compute(s);
|
let mut hash = md5::compute(s);
|
||||||
let mut repr = format!("{:x}", hash);
|
let mut repr = format!("{:x}", hash);
|
||||||
|
|
||||||
for _ in 0..2016 {
|
for _ in 0..extra {
|
||||||
hash = md5::compute(repr);
|
hash = md5::compute(repr);
|
||||||
repr = format!("{:x}", hash);
|
repr = format!("{:x}", hash);
|
||||||
}
|
}
|
||||||
@ -73,12 +27,9 @@ fn _gold (data: &I) -> O {
|
|||||||
if let Some(candidates) = candidates.get_mut(&c) {
|
if let Some(candidates) = candidates.get_mut(&c) {
|
||||||
let pos = candidates.iter().position(|pos| pos + 1000 > i);
|
let pos = candidates.iter().position(|pos| pos + 1000 > i);
|
||||||
if let Some(pos) = pos {
|
if let Some(pos) = pos {
|
||||||
let drained = candidates.drain(pos..).collect_vec();
|
done.extend(candidates.drain(pos..));
|
||||||
// println!("{} at: {:?} added to vec: {}", c, drained, repr);
|
|
||||||
|
|
||||||
done.extend(drained);
|
|
||||||
candidates.clear();
|
candidates.clear();
|
||||||
if done.len() >= 100 { // extra
|
if done.len() >= 100 { // should be pretty solid, but not sure if I can prove this!
|
||||||
done.sort();
|
done.sort();
|
||||||
return done[63];
|
return done[63];
|
||||||
}
|
}
|
||||||
@ -90,38 +41,31 @@ fn _gold (data: &I) -> O {
|
|||||||
candidates.entry(c).or_default().push(i);
|
candidates.entry(c).or_default().push(i);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// 15189: too high
|
|
||||||
0
|
0
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn _silver () -> O {
|
||||||
|
_solve(0)
|
||||||
|
}
|
||||||
|
|
||||||
|
fn _gold () -> O {
|
||||||
|
_solve(2016)
|
||||||
|
}
|
||||||
|
|
||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
mod test {
|
mod test {
|
||||||
use super::*;
|
use super::*;
|
||||||
|
|
||||||
fn read () -> I {
|
|
||||||
"qzyelonm"
|
|
||||||
}
|
|
||||||
|
|
||||||
#[test]
|
|
||||||
fn sample () {
|
|
||||||
let data = "";
|
|
||||||
let data = _parse(data);
|
|
||||||
|
|
||||||
assert_eq!(1, 1)
|
|
||||||
}
|
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn silver () {
|
fn silver () {
|
||||||
let data = read();
|
let ans = _silver();
|
||||||
let ans = _silver(&data);
|
|
||||||
|
|
||||||
assert_eq!(ans, 15168)
|
assert_eq!(ans, 15168)
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn gold () {
|
fn gold () {
|
||||||
let data = read();
|
let ans = _gold();
|
||||||
let ans = _gold(&data);
|
|
||||||
|
|
||||||
assert_eq!(ans, 20864)
|
assert_eq!(ans, 20864)
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user