diff --git a/2001_number_of_pairs_of_interchangeable_rectangles/Cargo.lock b/2001_number_of_pairs_of_interchangeable_rectangles/Cargo.lock new file mode 100644 index 0000000..1345a97 --- /dev/null +++ b/2001_number_of_pairs_of_interchangeable_rectangles/Cargo.lock @@ -0,0 +1,7 @@ +# This file is automatically @generated by Cargo. +# It is not intended for manual editing. +version = 4 + +[[package]] +name = "number_of_pairs_of_interchangeable_rectangles" +version = "0.1.0" diff --git a/2001_number_of_pairs_of_interchangeable_rectangles/Cargo.toml b/2001_number_of_pairs_of_interchangeable_rectangles/Cargo.toml new file mode 100644 index 0000000..4faf051 --- /dev/null +++ b/2001_number_of_pairs_of_interchangeable_rectangles/Cargo.toml @@ -0,0 +1,6 @@ +[package] +name = "number_of_pairs_of_interchangeable_rectangles" +version = "0.1.0" +edition = "2024" + +[dependencies] diff --git a/2001_number_of_pairs_of_interchangeable_rectangles/src/lib.rs b/2001_number_of_pairs_of_interchangeable_rectangles/src/lib.rs new file mode 100644 index 0000000..85727d3 --- /dev/null +++ b/2001_number_of_pairs_of_interchangeable_rectangles/src/lib.rs @@ -0,0 +1,28 @@ +pub struct Solution; + +impl Solution { + pub fn interchangeable_rectangles(rectangles: Vec>) -> i64 { + let mut groups = std::collections::HashMap::new(); + + for rect in rectangles { + let gcd = Solution::gcd(rect[0], rect[1]); + let ratio = (rect[0] / gcd, rect[1] / gcd); + groups + .entry(ratio) + .and_modify(|count| *count += 1) + .or_insert(1); + } + + groups.values().map(|&n| n * (n - 1) / 2).sum() + } + + fn gcd(a: i32, b: i32) -> i32 { + if a == 0 { + b + } else if a <= b { + Solution::gcd(b % a, a) + } else { + Solution::gcd(b, a) + } + } +}