gcd

Trait Gcd

Source
pub trait Gcd {
    // Required methods
    fn gcd(self, other: Self) -> Self;
    fn gcd_binary(self, other: Self) -> Self;
    fn gcd_euclid(self, other: Self) -> Self;
}

Required Methods§

Source

fn gcd(self, other: Self) -> Self

Determine greatest common divisor using gcd_binary.

§Examples
use gcd::Gcd;

assert_eq!(0, 0u8.gcd(0));
assert_eq!(10, 10u8.gcd(0));
assert_eq!(10, 0u8.gcd(10));
assert_eq!(10, 10u8.gcd(20));
assert_eq!(44, 2024u32.gcd(748));
Source

fn gcd_binary(self, other: Self) -> Self

Source

fn gcd_euclid(self, other: Self) -> Self

Dyn Compatibility§

This trait is not dyn compatible.

In older versions of Rust, dyn compatibility was called "object safety", so this trait is not object safe.

Implementations on Foreign Types§

Source§

impl Gcd for u8

Source§

fn gcd(self, other: u8) -> u8

Source§

fn gcd_binary(self, v: u8) -> u8

Source§

fn gcd_euclid(self, other: u8) -> u8

Source§

impl Gcd for u16

Source§

fn gcd(self, other: u16) -> u16

Source§

fn gcd_binary(self, v: u16) -> u16

Source§

fn gcd_euclid(self, other: u16) -> u16

Source§

impl Gcd for u32

Source§

fn gcd(self, other: u32) -> u32

Source§

fn gcd_binary(self, v: u32) -> u32

Source§

fn gcd_euclid(self, other: u32) -> u32

Source§

impl Gcd for u64

Source§

fn gcd(self, other: u64) -> u64

Source§

fn gcd_binary(self, v: u64) -> u64

Source§

fn gcd_euclid(self, other: u64) -> u64

Source§

impl Gcd for u128

Source§

fn gcd(self, other: u128) -> u128

Source§

fn gcd_binary(self, v: u128) -> u128

Source§

fn gcd_euclid(self, other: u128) -> u128

Source§

impl Gcd for usize

Source§

fn gcd(self, other: usize) -> usize

Source§

fn gcd_binary(self, v: usize) -> usize

Source§

fn gcd_euclid(self, other: usize) -> usize

Source§

impl Gcd for NonZeroU8

Source§

impl Gcd for NonZeroU16

Source§

impl Gcd for NonZeroU32

Source§

impl Gcd for NonZeroU64

Source§

impl Gcd for NonZeroU128

Source§

impl Gcd for NonZeroUsize

Implementors§