|
8 | 8 | // option. This file may not be copied, modified, or distributed
|
9 | 9 | // except according to those terms.
|
10 | 10 |
|
| 11 | +use core::slice::heapsort; |
11 | 12 | use core::result::Result::{Ok, Err};
|
12 | 13 | use rand::{Rng, XorShiftRng};
|
13 | 14 |
|
@@ -226,26 +227,43 @@ fn get_unchecked_mut_range() {
|
226 | 227 | #[test]
|
227 | 228 | fn sort_unstable() {
|
228 | 229 | let mut v = [0; 600];
|
229 |
| - let mut v1 = [0; 600]; |
| 230 | + let mut tmp = [0; 600]; |
230 | 231 | let mut rng = XorShiftRng::new_unseeded();
|
231 | 232 |
|
232 | 233 | for len in (2..25).chain(500..510) {
|
233 |
| - for &modulus in &[10, 1000] { |
| 234 | + let v = &mut v[0..len]; |
| 235 | + let tmp = &mut tmp[0..len]; |
| 236 | + |
| 237 | + for &modulus in &[5, 10, 100, 1000] { |
234 | 238 | for _ in 0..100 {
|
235 | 239 | for i in 0..len {
|
236 |
| - let num = rng.gen::<i32>() % modulus; |
237 |
| - v[i] = num; |
238 |
| - v1[i] = num; |
| 240 | + v[i] = rng.gen::<i32>() % modulus; |
239 | 241 | }
|
240 | 242 |
|
241 |
| - v.sort_unstable(); |
242 |
| - assert!(v.windows(2).all(|w| w[0] <= w[1])); |
243 |
| - |
244 |
| - v1.sort_unstable_by(|a, b| a.cmp(b)); |
245 |
| - assert!(v1.windows(2).all(|w| w[0] <= w[1])); |
246 |
| - |
247 |
| - v1.sort_unstable_by(|a, b| b.cmp(a)); |
248 |
| - assert!(v1.windows(2).all(|w| w[0] >= w[1])); |
| 243 | + // Sort in default order. |
| 244 | + tmp.copy_from_slice(v); |
| 245 | + tmp.sort_unstable(); |
| 246 | + assert!(tmp.windows(2).all(|w| w[0] <= w[1])); |
| 247 | + |
| 248 | + // Sort in ascending order. |
| 249 | + tmp.copy_from_slice(v); |
| 250 | + tmp.sort_unstable_by(|a, b| a.cmp(b)); |
| 251 | + assert!(tmp.windows(2).all(|w| w[0] <= w[1])); |
| 252 | + |
| 253 | + // Sort in descending order. |
| 254 | + tmp.copy_from_slice(v); |
| 255 | + tmp.sort_unstable_by(|a, b| b.cmp(a)); |
| 256 | + assert!(tmp.windows(2).all(|w| w[0] >= w[1])); |
| 257 | + |
| 258 | + // Test heapsort using `<` operator. |
| 259 | + tmp.copy_from_slice(v); |
| 260 | + heapsort(tmp, |a, b| a < b); |
| 261 | + assert!(tmp.windows(2).all(|w| w[0] <= w[1])); |
| 262 | + |
| 263 | + // Test heapsort using `>` operator. |
| 264 | + tmp.copy_from_slice(v); |
| 265 | + heapsort(tmp, |a, b| a > b); |
| 266 | + assert!(tmp.windows(2).all(|w| w[0] >= w[1])); |
249 | 267 | }
|
250 | 268 | }
|
251 | 269 | }
|
|
0 commit comments