pub const fn lex_dependent_pairs_stop_after_empty_ys<X: Clone, Y, S: ExhaustiveDependentPairsYsGenerator<X, Y, J>, I: Iterator<Item = X>, J: Iterator<Item = Y>>(
    xs: I,
    ys_generator: S,
) -> LexDependentPairs<X, Y, S, I, J> 
Expand description

Generates pairs $(x, y)$, where the possible values of $y$ depend on the value of $x$. $x$ values with no corresponding $y$ values are treated specially.

See lex_dependent_pairs for context.

If the output iterator encounters an $x$ value whose corresponding ys iterator is empty, the output iterator stops iterating altogether. This prevents the iterator from getting stuck if all ys iterators after a certain point are empty.

§Examples

use itertools::Itertools;
use malachite_base::tuples::exhaustive::{
    lex_dependent_pairs_stop_after_empty_ys, ExhaustiveDependentPairsYsGenerator,
};
use maplit::hashmap;
use std::collections::HashMap;
use std::hash::Hash;
use std::iter::Cloned;
use std::slice::Iter;

#[derive(Clone, Debug)]
struct DPGeneratorFromMap<X: Clone + Eq + Hash, Y: 'static + Clone> {
    map: HashMap<X, &'static [Y]>,
}

impl<X: Clone + Eq + Hash, Y: 'static + Clone>
    ExhaustiveDependentPairsYsGenerator<X, Y, Cloned<Iter<'static, Y>>>
    for DPGeneratorFromMap<X, Y>
{
    #[inline]
    fn get_ys(&self, x: &X) -> Cloned<Iter<'static, Y>> {
        self.map[x].iter().cloned()
    }
}

let xs = [1, 2, 3, 2, 3, 2, 2].iter().cloned();
let xss = lex_dependent_pairs_stop_after_empty_ys(
    xs,
    DPGeneratorFromMap {
        map: hashmap! {
            1 => &[100, 101, 102][..],
            2 => &[][..],
            3 => &[300, 301, 302][..]
        },
    },
)
.take(20)
.collect_vec();
// Stops after seeing 2, which maps to an empty iterator
assert_eq!(xss.as_slice(), &[(1, 100), (1, 101), (1, 102)]);