2019-12-16 16:34:30 +03:00
|
|
|
// Type casting in Rust is done via the usage of the `as` operator.
|
|
|
|
// Please note that the `as` operator is not only used when type casting.
|
|
|
|
// It also helps with renaming imports.
|
2020-07-11 05:01:38 +03:00
|
|
|
//
|
|
|
|
// The goal is to make sure that the division does not fail to compile
|
2020-09-07 20:09:27 +03:00
|
|
|
// and returns the proper type.
|
2019-12-16 16:34:30 +03:00
|
|
|
|
2019-12-16 19:33:00 +03:00
|
|
|
// I AM NOT DONE
|
2020-07-11 05:01:38 +03:00
|
|
|
|
2019-12-16 16:34:30 +03:00
|
|
|
fn average(values: &[f64]) -> f64 {
|
2020-08-10 17:24:21 +03:00
|
|
|
let total = values.iter().fold(0.0, |a, b| a + b);
|
2019-12-16 16:34:30 +03:00
|
|
|
total / values.len()
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
let values = [3.5, 0.3, 13.0, 11.7];
|
|
|
|
println!("{}", average(&values));
|
2020-07-11 05:01:38 +03:00
|
|
|
}
|
2020-09-07 20:09:27 +03:00
|
|
|
|
|
|
|
#[cfg(test)]
|
|
|
|
mod tests {
|
|
|
|
use super::*;
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn returns_proper_type_and_value() {
|
|
|
|
assert_eq!(average(&[3.5, 0.3, 13.0, 11.7]), 7.125);
|
|
|
|
}
|
|
|
|
}
|