rational_binary_search

Function rational_binary_search 

Source
pub fn rational_binary_search<T>(
    f: impl FnMut(&URational<T>) -> bool,
    n: T,
) -> SbtNode<T>
where T: Unsigned,
Examples found in repository?
crates/library_checker/src/number_theory/rational_approximation.rs (line 14)
7pub fn rational_approximation(reader: impl Read, mut writer: impl Write) {
8    let s = read_all_unchecked(reader);
9    let mut scanner = Scanner::new(&s);
10    scan!(scanner, t);
11    for _ in 0..t {
12        scan!(scanner, n: u64, x: u64, y: u64);
13        let x = URational::new_unchecked(x, y);
14        let sbt = rational_binary_search::<u64>(|&a| a <= x, n);
15        if matches!(sbt.l.cmp(&x), Ordering::Equal) {
16            iter_print!(writer, sbt.l.num, sbt.l.den, sbt.l.num, sbt.l.den);
17        } else {
18            iter_print!(writer, sbt.l.num, sbt.l.den, sbt.r.num, sbt.r.den);
19        }
20    }
21}