feat: 2348_number_of_zero_filled_subarrays
This commit is contained in:
parent
8ae5954097
commit
e7b97921a8
7
2348_number_of_zero_filled_subarrays/Cargo.lock
generated
Normal file
7
2348_number_of_zero_filled_subarrays/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 = "number_of_zero_filled_subarrays"
|
||||
version = "0.1.0"
|
6
2348_number_of_zero_filled_subarrays/Cargo.toml
Normal file
6
2348_number_of_zero_filled_subarrays/Cargo.toml
Normal file
@ -0,0 +1,6 @@
|
||||
[package]
|
||||
name = "number_of_zero_filled_subarrays"
|
||||
version = "0.1.0"
|
||||
edition = "2024"
|
||||
|
||||
[dependencies]
|
20
2348_number_of_zero_filled_subarrays/src/lib.rs
Normal file
20
2348_number_of_zero_filled_subarrays/src/lib.rs
Normal file
@ -0,0 +1,20 @@
|
||||
pub struct Solution;
|
||||
|
||||
impl Solution {
|
||||
pub fn zero_filled_subarray(mut nums: Vec<i32>) -> i64 {
|
||||
let mut result = 0i64;
|
||||
|
||||
let mut continuous_count = 0i64;
|
||||
nums.push(1);
|
||||
for num in nums {
|
||||
if num == 0 {
|
||||
continuous_count += 1;
|
||||
} else {
|
||||
result += (1 + continuous_count) * continuous_count / 2;
|
||||
continuous_count = 0;
|
||||
}
|
||||
}
|
||||
|
||||
result
|
||||
}
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user