let vec = iter::repeat("don't satisfy condition 1") // iterator such as next() always "don't " satisfy condition 1"
.take_while(|_| {
satisfycondition1.satisfy() // true is condition 1 is satisfied else false
})
.collect();
Этот код создает вектор из n
элементов с n
, равным количеству случаев, когда условие 1 не выполняется.
Я хотел бы сейчас создать вектор из n + m
элементов с n
, равным количеству раз, когда условие 1 не соблюдается, и m
число раз, когда условие 2 не соблюдается.
Код должен выглядеть примерно так:
let vec = iter::repeat("dont't satisfy condition 1")
.take_while(|_| {
satisfycondition1.satisfy()
})
.union(
iter::repeat("has satisfed condition 1 but not 2 yet")
.take_while(|_| {
satisfycondition2.satisfy()
})
)
.collect();
Я знаю, что мог бы создать два вектора и затем объединить их, но это менее эффективно.
Вы можете использовать этот код, чтобы понять, что повторяется:
use std::iter;
fn main() {
let mut c = 0;
let z: Vec<_> = iter::repeat("dont't satisfy condition 1")
.take_while(|_| {
c = c + 1;
let rep = if c < 5 { true } else { false };
rep
})
.collect();
println!("------{:?}", z);
}