|
| 1 | +use time::PreciseTime; |
| 2 | + |
| 3 | +fn swap(val: &mut Vec<i32>, a: usize, b: usize) { |
| 4 | + val[a] = val[a] ^ val[b]; |
| 5 | + val[b] = val[a] ^ val[b]; |
| 6 | + val[a] = val[a] ^ val[b]; |
| 7 | +} |
| 8 | + |
| 9 | +// 选择 |
| 10 | +fn select(val: &Vec<i32>) -> Vec<i32> { |
| 11 | + let mut value = val.clone(); |
| 12 | + for i in 0..value.len() - 1 { |
| 13 | + let mut min = i; |
| 14 | + for n in i+1..value.len() { |
| 15 | + if value[n] < value[min] { |
| 16 | + min = n; |
| 17 | + } |
| 18 | + } |
| 19 | + if min != i { |
| 20 | + swap(&mut value, min, i); |
| 21 | + } |
| 22 | + } |
| 23 | + value |
| 24 | +} |
| 25 | + |
| 26 | +// 优化1 |
| 27 | +fn select1(val: &Vec<i32>) -> Vec<i32> { |
| 28 | + let mut value = val.clone(); |
| 29 | + let mut left = 0; |
| 30 | + let mut right = value.len() - 1; |
| 31 | + |
| 32 | + while left < right { |
| 33 | + let mut min = left; |
| 34 | + let mut max = right; |
| 35 | + |
| 36 | + for n in left..right+1 { // 需要循环到right下标,因此需要加1 |
| 37 | + if value[min] > value[n] { |
| 38 | + min = n; |
| 39 | + } |
| 40 | + if value[max] < value[n] { |
| 41 | + max = n; |
| 42 | + } |
| 43 | + } |
| 44 | + println!("min: {}, max: {}, left: {}, right: {}", min, max, left, right); |
| 45 | + println!("min value: {}, max value: {}", value[min], value[max]); |
| 46 | + |
| 47 | + if min == right && max == left { |
| 48 | + swap(&mut value, left, right); |
| 49 | + } else { |
| 50 | + if min != left { |
| 51 | +// if min == right { |
| 52 | +// right = |
| 53 | +// } |
| 54 | + swap(&mut value, min, left); |
| 55 | + } |
| 56 | + if max != right { |
| 57 | + swap(&mut value, if max == left { min } else { max }, right); |
| 58 | + } |
| 59 | + } |
| 60 | +// if value[min] < value[left] && min != left { |
| 61 | +// swap(&mut value, min, left); |
| 62 | +// } |
| 63 | +// if value[max] > value[right] && max != right { |
| 64 | +// swap(&mut value, max, right); |
| 65 | +// } |
| 66 | + println!("{:?}", value); |
| 67 | + left+=1; |
| 68 | + right-=1; |
| 69 | + } |
| 70 | + value |
| 71 | +} |
| 72 | + |
| 73 | +pub fn test(array_value: &Vec<i32>) { |
| 74 | + println!("Start test select sort:{:?}", array_value); |
| 75 | + |
| 76 | + let start_select = PreciseTime::now(); |
| 77 | + let a = select(&array_value); |
| 78 | + let end_select = PreciseTime::now(); |
| 79 | + println!("select take time {}", start_select.to(end_select)); |
| 80 | + |
| 81 | + let start_select = PreciseTime::now(); |
| 82 | + let b = select1(&array_value); |
| 83 | + let end_select = PreciseTime::now(); |
| 84 | + println!("select1 take time {}", start_select.to(end_select)); |
| 85 | + |
| 86 | + println!("{:?}", a); |
| 87 | + println!("{:?}", b); |
| 88 | + println!("{}", a == b); |
| 89 | +} |
0 commit comments