Merge branch 'refactor'
This commit is contained in:
@@ -1,8 +1,12 @@
|
|||||||
|
#![warn(clippy::all, clippy::pedantic)]
|
||||||
|
#![allow(clippy::clippy::cast_precision_loss)]
|
||||||
|
|
||||||
mod stats;
|
mod stats;
|
||||||
|
|
||||||
fn main() {
|
fn main() {
|
||||||
// Stats
|
// Stats
|
||||||
let mut numbers = stats::StatsCalculator::default_data();
|
let mut data = vec![1, 2, 3, 4, 5, 6, 7, 8, 9, 10];
|
||||||
|
let mut numbers = stats::NewStatsCalculator::from_vec(&mut data);
|
||||||
println!("Data: {:?}", numbers);
|
println!("Data: {:?}", numbers);
|
||||||
println!("Mean: {:?}", numbers.get_mean());
|
println!("Mean: {:?}", numbers.get_mean());
|
||||||
println!("Median: {:?}", numbers.get_median());
|
println!("Median: {:?}", numbers.get_median());
|
||||||
|
|||||||
103
src/stats.rs
103
src/stats.rs
@@ -1,17 +1,24 @@
|
|||||||
use std::convert::TryFrom;
|
use std::convert::TryFrom;
|
||||||
|
use ::std::collections::HashMap;
|
||||||
|
|
||||||
|
|
||||||
#[derive(Debug)]
|
#[derive(Debug)]
|
||||||
pub struct StatsCalculator {
|
pub struct NewStatsCalculator<'a> {
|
||||||
data: Vec<i32>,
|
data: &'a mut Vec<i32>,
|
||||||
|
length: u32,
|
||||||
|
total: i32,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl StatsCalculator {
|
impl<'a> NewStatsCalculator<'a> {
|
||||||
pub fn default_data() -> Self {
|
pub fn from_vec(initial_data: &'a mut Vec<i32>) -> Self {
|
||||||
Self::from_vec(vec![1, 2, 3, 4, 5, 6, 7, 8, 9, 10])
|
let mut instance = NewStatsCalculator {
|
||||||
}
|
data: initial_data,
|
||||||
|
length: 0,
|
||||||
pub fn from_vec(initial_data: Vec<i32>) -> Self {
|
total: 0,
|
||||||
return StatsCalculator { data: initial_data };
|
};
|
||||||
|
instance.get_length();
|
||||||
|
instance.get_total();
|
||||||
|
instance
|
||||||
}
|
}
|
||||||
|
|
||||||
// pub fn initialise(&mut self) -> () {
|
// pub fn initialise(&mut self) -> () {
|
||||||
@@ -28,36 +35,84 @@ impl StatsCalculator {
|
|||||||
// }
|
// }
|
||||||
// }
|
// }
|
||||||
|
|
||||||
fn get_length(&self) -> i32 {
|
fn get_length(&mut self) {
|
||||||
let length = i32::try_from(self.data.len());
|
let length = u32::try_from(self.data.len());
|
||||||
|
|
||||||
if let Ok(i) = length {
|
if let Ok(i) = length {
|
||||||
return i;
|
self.length = i;
|
||||||
} else {
|
} else {
|
||||||
return 0;
|
self.length = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn get_total(&self) -> i32 {
|
fn get_total(&mut self) {
|
||||||
return self.data.iter().sum();
|
self.total = self.data.iter().sum();
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn get_mean(&self) -> f32 {
|
pub fn get_mean(&self) -> f32 {
|
||||||
let total = self.get_total();
|
self.total as f32 / self.length as f32
|
||||||
let length = self.get_length();
|
|
||||||
return total as f32 / length as f32;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn get_median(&mut self) -> f32 {
|
pub fn get_median(&mut self) -> f32 {
|
||||||
let length = self.get_length();
|
let mid = self.length as usize / 2;
|
||||||
let mid = length as usize / 2;
|
|
||||||
|
|
||||||
self.data.sort();
|
self.data.sort_unstable();
|
||||||
|
|
||||||
if length % 2 != 0 {
|
if self.length % 2 == 0 {
|
||||||
return self.data[mid] as f32;
|
(self.data[mid - 1] as f32 + self.data[mid] as f32) / 2.0
|
||||||
} else {
|
} else {
|
||||||
return (self.data[mid - 1] as f32 + self.data[mid] as f32) / 2.0;
|
self.data[mid] as f32
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// pub fn get_mode(&self) -> HashMap<&mut i32, i32> {
|
||||||
|
// let mut mode = HashMap::new();
|
||||||
|
// for ref i in self.data {
|
||||||
|
// let count = mode.entry(i).or_insert(0);
|
||||||
|
// *count += 1;
|
||||||
|
// }
|
||||||
|
// mode
|
||||||
|
// }
|
||||||
|
}
|
||||||
|
|
||||||
|
#[cfg(test)]
|
||||||
|
mod test {
|
||||||
|
use super::*;
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_get_length() {
|
||||||
|
let mut data = vec![1, 2, 3, 4, 5, 6];
|
||||||
|
let mut test = NewStatsCalculator::from_vec(&mut data);
|
||||||
|
test.get_length();
|
||||||
|
assert_eq!(test.length, 6);
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_get_total() {
|
||||||
|
let mut data = vec![1, 2, 3, 4, 5, 6];
|
||||||
|
let mut test = NewStatsCalculator::from_vec(&mut data);
|
||||||
|
test.get_length();
|
||||||
|
assert_eq!(test.total, 21);
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_get_mean() {
|
||||||
|
let mut data = vec![1, 2, 3, 4, 5, 6];
|
||||||
|
let test = NewStatsCalculator::from_vec(&mut data);
|
||||||
|
assert_eq!(test.get_mean(), 3.5);
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_get_median_even() {
|
||||||
|
let mut data = vec![1, 2, 3, 4, 5, 6];
|
||||||
|
let mut test = NewStatsCalculator::from_vec(&mut data);
|
||||||
|
assert_eq!(test.get_median(), 3.5);
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_get_median_odd() {
|
||||||
|
let mut data = vec![1, 2, 3, 4, 5, 6, 7];
|
||||||
|
let mut test = NewStatsCalculator::from_vec(&mut data);
|
||||||
|
assert_eq!(test.get_median(), 4.0);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user