2019-12-16 15:34:30 +02: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 04:01:38 +02:00
|
|
|
//
|
|
|
|
// The goal is to make sure that the division does not fail to compile
|
2020-09-07 19:09:27 +02:00
|
|
|
// and returns the proper type.
|
2019-12-16 15:34:30 +02:00
|
|
|
|
2019-12-16 18:33:00 +02:00
|
|
|
// I AM NOT DONE
|
2020-07-11 04:01:38 +02:00
|
|
|
|
2019-12-16 15:34:30 +02:00
|
|
|
fn average(values: &[f64]) -> f64 {
|
2022-04-19 17:37:00 +02:00
|
|
|
let total = values.iter().sum::<f64>();
|
2019-12-16 15:34:30 +02:00
|
|
|
total / values.len()
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
let values = [3.5, 0.3, 13.0, 11.7];
|
|
|
|
println!("{}", average(&values));
|
2020-07-11 04:01:38 +02:00
|
|
|
}
|
2020-09-07 19:09:27 +02: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);
|
|
|
|
}
|
|
|
|
}
|