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
60
|
use rayon::prelude::*;
#[test]
fn check_intersperse() {
let v: Vec<_> = (0..1000).into_par_iter().intersperse(-1).collect();
assert_eq!(v.len(), 1999);
for (i, x) in v.into_iter().enumerate() {
assert_eq!(x, if i % 2 == 0 { i as i32 / 2 } else { -1 });
}
}
#[test]
fn check_intersperse_again() {
let v: Vec<_> = (0..1000)
.into_par_iter()
.intersperse(-1)
.intersperse(-2)
.collect();
assert_eq!(v.len(), 3997);
for (i, x) in v.into_iter().enumerate() {
let y = match i % 4 {
0 => i as i32 / 4,
2 => -1,
_ => -2,
};
assert_eq!(x, y);
}
}
#[test]
fn check_intersperse_unindexed() {
let v: Vec<_> = (0..1000).map(|i| i.to_string()).collect();
let s = v.join(",");
let s2 = v.join(";");
let par: String = s.par_split(',').intersperse(";").collect();
assert_eq!(par, s2);
}
#[test]
fn check_intersperse_producer() {
(0..1000)
.into_par_iter()
.intersperse(-1)
.zip_eq(0..1999)
.for_each(|(x, i)| {
assert_eq!(x, if i % 2 == 0 { i / 2 } else { -1 });
});
}
#[test]
fn check_intersperse_rev() {
(0..1000)
.into_par_iter()
.intersperse(-1)
.zip_eq(0..1999)
.rev()
.for_each(|(x, i)| {
assert_eq!(x, if i % 2 == 0 { i / 2 } else { -1 });
});
}
|