feat: 611_valid_triangle_number
This commit is contained in:
parent
493b9c50c5
commit
6a51947dcf
7
611_valid_triangle_number/Cargo.lock
generated
Normal file
7
611_valid_triangle_number/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 = "valid_triangle_number"
|
||||
version = "0.1.0"
|
6
611_valid_triangle_number/Cargo.toml
Normal file
6
611_valid_triangle_number/Cargo.toml
Normal file
@ -0,0 +1,6 @@
|
||||
[package]
|
||||
name = "valid_triangle_number"
|
||||
version = "0.1.0"
|
||||
edition = "2024"
|
||||
|
||||
[dependencies]
|
27
611_valid_triangle_number/src/lib.rs
Normal file
27
611_valid_triangle_number/src/lib.rs
Normal file
@ -0,0 +1,27 @@
|
||||
pub struct Solution;
|
||||
|
||||
impl Solution {
|
||||
pub fn triangle_number(mut nums: Vec<i32>) -> i32 {
|
||||
let mut count = 0;
|
||||
|
||||
nums.sort();
|
||||
for (c_index, &c) in nums.iter().enumerate().skip(2) {
|
||||
let mut a_index = 0;
|
||||
let mut b_index = c_index - 1;
|
||||
|
||||
while a_index < b_index {
|
||||
let a = nums[a_index];
|
||||
let b = nums[b_index];
|
||||
|
||||
if a + b > c {
|
||||
count += (b_index - a_index) as i32;
|
||||
b_index -= 1;
|
||||
} else {
|
||||
a_index += 1;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
count
|
||||
}
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user