2023-05-29 17:39:08 +00:00
|
|
|
// using_as.rs
|
2020-07-11 02:01:38 +00:00
|
|
|
//
|
2023-05-29 17:39:08 +00: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.
|
|
|
|
//
|
|
|
|
// The goal is to make sure that the division does not fail to compile and
|
|
|
|
// returns the proper type.
|
|
|
|
//
|
|
|
|
// Execute `rustlings hint using_as` or use the `hint` watch subcommand for a
|
|
|
|
// hint.
|
2019-12-16 13:34:30 +00:00
|
|
|
|
|
|
|
fn average(values: &[f64]) -> f64 {
|
2022-04-19 15:37:00 +00:00
|
|
|
let total = values.iter().sum::<f64>();
|
2023-09-10 16:38:07 +00:00
|
|
|
total / values.len() as f64
|
2019-12-16 13:34:30 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
let values = [3.5, 0.3, 13.0, 11.7];
|
|
|
|
println!("{}", average(&values));
|
2020-07-11 02:01:38 +00:00
|
|
|
}
|
2020-09-07 17:09:27 +00: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);
|
|
|
|
}
|
|
|
|
}
|