1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
pub fn largest_isize(list: &[isize]) -> isize {
let mut largest = list[0];
for &item in list.iter() {
if item > largest{
largest = item;
}
}
largest
}
pub struct AverageList {
list: Vec<i32>,
average: f64,
}
impl AverageList {
pub fn add(&mut self, value: i32) {
self.list.push(value);
self.update_average();
}
pub fn remove(&mut self) -> Option<i32> {
let result = self.list.pop();
match result {
Some(value) => {
self.update_average();
Some(value)
},
None => None,
}
}
pub fn average(&mut self) -> f64 {
self.average
}
fn update_average(&mut self) {
let total: i32 = self.list.iter().sum();
self.average = total as f64 / self.list.len() as f64;
}
}
#[test]
fn largest_isize_test(){
let list = vec!(1,6,2);
let largest = largest_isize(&list);
assert_eq!(largest, 6);
println!("{}",largest);
}
#[test]
fn average_list_test(){
let mut list = AverageList{
list: vec!(3),
average: 3 as f64
};
for x in 1..6 {
list.add(x);
}
let num = 3;
assert_eq!(num as f64,list.average);
}