给定一个值为T
的向量向量,即Vec<Vec<T>>
。
怎么优雅地检查内部向量是否具有相同的长度?(不依赖于外部库)
也就是说,如果所有内部向量的长度相同,则为true
,否则为false
。
给定一个值为T
的向量向量,即Vec<Vec<T>>
。
怎么优雅地检查内部向量是否具有相同的长度?(不依赖于外部库)
也就是说,如果所有内部向量的长度相同,则为true
,否则为false
。
all
方法来检查迭代器的所有元素是否与谓词匹配。然后只需将其与列表中的第一个元素进行比较。fn main() {
let vec_of_vecs = vec![
vec![1, 2, 3],
vec![1, 2, 3],
vec![1, 2, 3],
vec![1, 2, 3],
vec![1, 2, 3],
vec![1, 2, 3, 4], // remove this to prove that it works for both cases
];
let all_same_length = vec_of_vecs
.iter()
.all(|ref v| v.len() == vec_of_vecs[0].len());
if all_same_length {
println!("They're all the same");
} else {
println!("They are not the same");
}
}
all_equal
函数 - 将 Vec
映射到它们的长度,然后运行它。但是它需要一个外部依赖。 - Michailitertools
。让我们假设没有外部依赖(更新问题)。 - kentwaitvec_of_vecs
为空时,这会导致恐慌。 - Jorge Leitao我认为更通用和惯用的解决方案是:
fn all_eq_len<'a, T, E: 'a>(collection: T) -> bool
where
T: IntoIterator<Item = &'a Vec<E>>,
{
let mut iter = collection.into_iter();
if let Some(first) = iter.next() {
let len = first.len();
iter.all(|v| v.len() == len)
} else {
true
}
}
use itertools::Itertools;
vec_of_vecs.iter().map(|v| v.len()).all_equal()