Trait Gcd

Source
pub trait Gcd<Rhs = Self> {
    type Output;

    // Required method
    fn gcd(self, rhs: Rhs) -> Self::Output;
}
Expand description

Compute the greatest common divisor.

For negative integers, the common divisor is still kept positive.

§Examples

use dashu_base::Gcd;
assert_eq!(12u8.gcd(10u8), 2);

§Panics

Panics if both operands are zeros

Required Associated Types§

Required Methods§

Source

fn gcd(self, rhs: Rhs) -> Self::Output

Compute the greatest common divisor between the two operands.

Panics if both operands are zeros

Implementations on Foreign Types§

Source§

impl Gcd for u8

Source§

type Output = u8

Source§

fn gcd(self, rhs: u8) -> <u8 as Gcd>::Output

Source§

impl Gcd for u16

Source§

type Output = u16

Source§

fn gcd(self, rhs: u16) -> <u16 as Gcd>::Output

Source§

impl Gcd for u32

Source§

type Output = u32

Source§

fn gcd(self, rhs: u32) -> <u32 as Gcd>::Output

Source§

impl Gcd for u64

Source§

type Output = u64

Source§

fn gcd(self, rhs: u64) -> <u64 as Gcd>::Output

Source§

impl Gcd for u128

Source§

type Output = u128

Source§

fn gcd(self, rhs: u128) -> <u128 as Gcd>::Output

Source§

impl Gcd for usize

Source§

type Output = usize

Source§

fn gcd(self, rhs: usize) -> <usize as Gcd>::Output

Implementors§

Source§

impl Gcd for IBig

Source§

impl Gcd for UBig

Source§

impl Gcd<IBig> for UBig

Source§

impl Gcd<UBig> for IBig

Source§

impl<'l> Gcd<IBig> for &'l IBig

Source§

impl<'l> Gcd<IBig> for &'l UBig

Source§

impl<'l> Gcd<UBig> for &'l IBig

Source§

impl<'l> Gcd<UBig> for &'l UBig

Source§

impl<'l, 'r> Gcd<&'r IBig> for &'l IBig

Source§

impl<'l, 'r> Gcd<&'r IBig> for &'l UBig

Source§

impl<'l, 'r> Gcd<&'r UBig> for &'l IBig

Source§

impl<'l, 'r> Gcd<&'r UBig> for &'l UBig

Source§

impl<'r> Gcd<&'r IBig> for IBig

Source§

impl<'r> Gcd<&'r IBig> for UBig

Source§

impl<'r> Gcd<&'r UBig> for IBig

Source§

impl<'r> Gcd<&'r UBig> for UBig