Function malachite_base::num::exhaustive::exhaustive_signed_range

source ·
pub fn exhaustive_signed_range<T: PrimitiveSigned>(
    a: T,
    b: T,
) -> ExhaustiveSignedRange<T> 
Expand description

Generates all signed integers in the half-open interval $[a, b)$, in order of increasing absolute value.

When two numbers have the same absolute value, the positive one comes first. $a$ must be less than or equal to $b$. If $a$ and $b$ are equal, the range is empty. This function cannot create a range that includes T::MAX; for that, use exhaustive_signed_inclusive_range.

The output satisfies $(|x_i|, \operatorname{sgn}(-x_i)) <_\mathrm{lex} (|x_j|, \operatorname{sgn}(-x_j))$ whenever $i, j \in [0, b - a)$ and $i < j$.

The output length is $b - a$.

§Complexity per iteration

Constant time and additional memory.

§Panics

Panics if $a > b$.

§Examples

use itertools::Itertools;
use malachite_base::num::exhaustive::exhaustive_signed_range;

assert_eq!(
    exhaustive_signed_range::<i8>(-5, 5).collect_vec(),
    &[0, 1, -1, 2, -2, 3, -3, 4, -4, -5]
)