programmieren-in-rust/aufgaben/sheet2/task2/sort.rs

53 lines
1.4 KiB
Rust
Raw Normal View History

2016-11-02 02:01:05 +01:00
fn main() {
let mut arr = [61, 21, 27, 79, 57, 60, 46, 42, 27, 92, 66, 26];
sort(&mut arr);
2016-11-06 23:48:18 +01:00
println!("{:?}", arr);
2016-11-02 02:01:05 +01:00
}
2016-11-06 23:48:18 +01:00
fn sort(arr: &mut [i32]) {
let mut min;
let mut temp = 0;
let mut pointer = 0;
let length = arr.len();
for counter in 0..length {
min = arr[counter];
// läuft unsortierten teil des arrays ab
for counter2 in 0..length {
let iter = counter2 + counter;
if iter > length - 1{
break;
}
if arr[iter] <= min {
min = arr[iter];
temp = arr[counter];
pointer = iter;
}
// tausche min an die richtige Stelle
arr[counter] = min;
arr[pointer] = temp;
}
}
}
2016-11-02 02:01:05 +01:00
#[test]
fn sort_array() {
let mut arr = [
61, 21, 27, 79, 57, 60, 46, 92, 66, 26, 37, 15, 29, 70, 30, 55, 62, 81,
84, 35, 34, 52, 98, 50, 39, 42, 41, 24, 28, 64, 95, 47, 43, 23, 14, 71,
78, 86, 51, 20, 9, 1, 18, 17, 94, 33, 3, 91, 65, 2, 38, 59, 96, 8, 83,
19, 90, 63, 16, 58, 68, 48
];
sort(&mut arr);
assert_eq!(&arr as &[u64], &[
1u64, 2, 3, 8, 9, 14, 15, 16, 17, 18, 19, 20, 21, 23, 24, 26, 27, 28, 29,
30, 33, 34, 35, 37, 38, 39, 41, 42, 43, 46, 47, 48, 50, 51, 52, 55, 57,
58, 59, 60, 61, 62, 63, 64, 65, 66, 68, 70, 71, 78, 79, 81, 83, 84, 86,
90, 91, 92, 94, 95, 96, 98,
] as &[u64]);
}
2016-11-06 23:48:18 +01:00