pub type T = int; pub const bits: uint = uint::bits; /// Returns `base` raised to the power of `exponent` pub fn pow(base: int, exponent: uint) -> int { if exponent == 0u { return 1; } //Not mathemtically true if ~[base == 0] if base == 0 { return 0; } let mut my_pow = exponent; let mut acc = 1; let mut multiplier = base; while(my_pow > 0u) { if my_pow % 2u == 1u { acc *= multiplier; } my_pow /= 2u; multiplier *= multiplier; } return acc; } #[test] fn test_pow() { assert (pow(0, 0u) == 1); assert (pow(0, 1u) == 0); assert (pow(0, 2u) == 0); assert (pow(-1, 0u) == 1); assert (pow(1, 0u) == 1); assert (pow(-3, 2u) == 9); assert (pow(-3, 3u) == -27); assert (pow(4, 9u) == 262144); } #[test] fn test_overflows() { assert (max_value > 0); assert (min_value <= 0); assert (min_value + max_value + 1 == 0); }