Skip to content

Commit

Permalink
2024-13
Browse files Browse the repository at this point in the history
  • Loading branch information
jurisk committed Dec 13, 2024
1 parent 790816d commit 43e1672
Show file tree
Hide file tree
Showing 15 changed files with 1,722 additions and 20 deletions.
42 changes: 42 additions & 0 deletions rust/common/src/bool_ops.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,42 @@
pub trait BoolOptionOps {
fn then_some_unit(self) -> Option<()>;
fn then_none(self) -> Option<()>;
}

impl BoolOptionOps for bool {
fn then_some_unit(self) -> Option<()> {
if self { Some(()) } else { None }
}

fn then_none(self) -> Option<()> {
if self { None } else { Some(()) }
}
}

pub trait BoolResultOps {
#[expect(clippy::missing_errors_doc)]
fn then_ok_unit<E, FE>(self, error: FE) -> Result<(), E>
where
FE: FnOnce() -> E;

#[expect(clippy::missing_errors_doc)]
fn then_err_unit<E, FE>(self, error: FE) -> Result<(), E>
where
FE: FnOnce() -> E;
}

impl BoolResultOps for bool {
fn then_ok_unit<E, FE>(self, error: FE) -> Result<(), E>
where
FE: FnOnce() -> E,
{
if self { Ok(()) } else { Err(error()) }
}

fn then_err_unit<E, FE>(self, error: FE) -> Result<(), E>
where
FE: FnOnce() -> E,
{
if self { Err(error()) } else { Ok(()) }
}
}
1 change: 1 addition & 0 deletions rust/common/src/lib.rs
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
#![feature(step_trait)]

pub mod area2d;
pub mod bool_ops;
pub mod circular;
pub mod coords2d;
pub mod coords3d;
Expand Down
45 changes: 45 additions & 0 deletions rust/common/src/math.rs
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
use num_traits::Num;

#[must_use]
#[allow(clippy::cast_possible_truncation, clippy::cast_sign_loss)]
pub fn factors(n: u32) -> Vec<u32> {
Expand Down Expand Up @@ -61,3 +63,46 @@ pub fn gcd(a: i64, b: i64) -> i64 {
pub fn lcm(a: i64, b: i64) -> i64 {
a.abs() * b.abs() / gcd(a, b)
}

#[must_use]
pub fn solve_two_variable_integer_linear_equation_system<N: Num + Copy>(
a: N,
b: N,
c: N,
d: N,
e: N,
f: N,
) -> Option<(N, N)> {
let div = |dividend: N, divisor: N| -> Option<N> {
(dividend % divisor == N::zero()).then(|| dividend / divisor)
};

let det = a * d - b * c;
if det == N::zero() {
None
} else {
let x = div(e * d - b * f, det);
let y = div(a * f - e * c, det);
match (x, y) {
(Some(x), Some(y)) => Some((x, y)),
_ => None,
}
}
}

#[cfg(test)]
mod tests {
use super::*;

#[test]
fn test_solve_two_variable_integer_linear_equation_system() {
assert_eq!(
solve_two_variable_integer_linear_equation_system(2, 1, 3, -1, 15, 5),
Some((4, 7))
);
assert_eq!(
solve_two_variable_integer_linear_equation_system(1, 2, 1, 2, 5, 6),
None
);
}
}
10 changes: 10 additions & 0 deletions rust/common/src/parsing.rs
Original file line number Diff line number Diff line change
Expand Up @@ -272,6 +272,16 @@ pub fn segments_separated_by_double_newline(input: &str) -> Vec<String> {
.collect()
}

pub fn parse_segments_separated_by_double_newline<T: FromStr>(input: &str) -> Result<Vec<T>, Error>
where
<T as FromStr>::Err: Debug,
{
segments_separated_by_double_newline(input)
.into_iter()
.map(|x| parse_str(&x))
.collect()
}

/// # Errors
///
/// Will return `Err` if parsing fails.
Expand Down
16 changes: 15 additions & 1 deletion rust/y2024/resources/13-test-00.txt
Original file line number Diff line number Diff line change
@@ -1 +1,15 @@
noop
Button A: X+94, Y+34
Button B: X+22, Y+67
Prize: X=8400, Y=5400

Button A: X+26, Y+66
Button B: X+67, Y+21
Prize: X=12748, Y=12176

Button A: X+17, Y+86
Button B: X+84, Y+37
Prize: X=7870, Y=6450

Button A: X+69, Y+23
Button B: X+27, Y+71
Prize: X=18641, Y=10279
Loading

0 comments on commit 43e1672

Please sign in to comment.