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
use std::cmp::min;
pub struct RangeChunk { i: usize, n: usize, chunk: usize }
pub fn range_chunk(n: usize, chunk: usize) -> RangeChunk {
RangeChunk {
i: 0,
n: n,
chunk: chunk,
}
}
impl Iterator for RangeChunk {
type Item = (usize, usize);
#[inline]
fn next(&mut self) -> Option<Self::Item> {
if self.n == 0 {
None
} else {
let i = self.i;
let rem = min(self.n, self.chunk);
self.i += 1;
self.n -= rem;
Some((i, rem))
}
}
}
#[inline]
pub fn round_up_to(x: usize, multiple_of: usize) -> usize {
let (mut d, r) = (x / multiple_of, x % multiple_of);
if r > 0 { d += 1; }
d * multiple_of
}