feat: 1814_count_nice_pairs_in_an_array
This commit is contained in:
parent
13d530c652
commit
c3bf3ec5da
7
1814_count_nice_pairs_in_an_array/Cargo.lock
generated
Normal file
7
1814_count_nice_pairs_in_an_array/Cargo.lock
generated
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
# This file is automatically @generated by Cargo.
|
||||||
|
# It is not intended for manual editing.
|
||||||
|
version = 4
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "count_nice_pairs_in_an_array"
|
||||||
|
version = "0.1.0"
|
6
1814_count_nice_pairs_in_an_array/Cargo.toml
Normal file
6
1814_count_nice_pairs_in_an_array/Cargo.toml
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
[package]
|
||||||
|
name = "count_nice_pairs_in_an_array"
|
||||||
|
version = "0.1.0"
|
||||||
|
edition = "2024"
|
||||||
|
|
||||||
|
[dependencies]
|
29
1814_count_nice_pairs_in_an_array/src/lib.rs
Normal file
29
1814_count_nice_pairs_in_an_array/src/lib.rs
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
pub struct Solution;
|
||||||
|
|
||||||
|
impl Solution {
|
||||||
|
pub fn count_nice_pairs(nums: Vec<i32>) -> i32 {
|
||||||
|
const MOD: i64 = 1_000_000_007;
|
||||||
|
|
||||||
|
let mut groups = std::collections::HashMap::<i32, i64>::new();
|
||||||
|
for n in nums {
|
||||||
|
let num_sub_rev = n - Solution::rev(n);
|
||||||
|
groups
|
||||||
|
.entry(num_sub_rev)
|
||||||
|
.and_modify(|count| *count += 1)
|
||||||
|
.or_insert(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
let result: i64 = groups.values().map(|count| count * (count - 1) / 2).sum();
|
||||||
|
(result % MOD) as i32
|
||||||
|
}
|
||||||
|
|
||||||
|
fn rev(mut num: i32) -> i32 {
|
||||||
|
let mut result = 0;
|
||||||
|
while num > 0 {
|
||||||
|
result *= 10;
|
||||||
|
result += num % 10;
|
||||||
|
num /= 10;
|
||||||
|
}
|
||||||
|
result
|
||||||
|
}
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user