2012-09-28 12:03:54 -07:00
|
|
|
pub type T = int;
|
|
|
|
pub const bits: uint = uint::bits;
|
2011-12-13 16:25:51 -08:00
|
|
|
|
2012-07-04 22:53:12 +01:00
|
|
|
/// Returns `base` raised to the power of `exponent`
|
2012-09-28 12:03:54 -07:00
|
|
|
pub fn pow(base: int, exponent: uint) -> int {
|
2012-08-01 17:30:05 -07:00
|
|
|
if exponent == 0u { return 1; } //Not mathemtically true if ~[base == 0]
|
|
|
|
if base == 0 { return 0; }
|
2012-03-06 20:48:40 -08:00
|
|
|
let mut my_pow = exponent;
|
|
|
|
let mut acc = 1;
|
|
|
|
let mut multiplier = base;
|
2011-12-13 16:25:51 -08:00
|
|
|
while(my_pow > 0u) {
|
|
|
|
if my_pow % 2u == 1u {
|
|
|
|
acc *= multiplier;
|
|
|
|
}
|
|
|
|
my_pow /= 2u;
|
|
|
|
multiplier *= multiplier;
|
|
|
|
}
|
2012-08-01 17:30:05 -07:00
|
|
|
return acc;
|
2011-12-13 16:25:51 -08:00
|
|
|
}
|
2012-01-17 17:28:21 -08:00
|
|
|
|
|
|
|
#[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);
|
|
|
|
}
|