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
use RosalindResult;
use RosalindError::MotifStringsLengthError;
pub fn motif_lookup(s: &str, t: &str) -> RosalindResult<Vec<usize>> {
let (s_len, t_len) = (s.len(), t.len());
if s_len < t_len { return Err(MotifStringsLengthError); }
let mut motif: Vec<usize> = Vec::new();
for i in 0..(s_len - t_len + 1) {
if s[i..].starts_with(t) { motif.push(i + 1); }
}
Ok(motif)
}
#[cfg(test)]
mod tests {
use super::motif_lookup;
use super::super::RosalindError::MotifStringsLengthError;
#[test]
fn it_should_return_all_locations_of_substring_t_in_s() {
let s = "GATATATGCATATACTT";
let t = "ATAT";
assert_eq!(motif_lookup(s, t).unwrap(), vec![2, 4, 10]);
}
#[test]
fn it_should_return_error_when_substring_t_is_longer_than_s() {
let s = "ATAT";
let t = "GATATATGCATATACTT";
assert_eq!(motif_lookup(s, t).unwrap_err(), MotifStringsLengthError);
}
}