forked from aylei/leetcode-rust
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathn0028_implement_strstr.rs
50 lines (45 loc) · 1.32 KB
/
n0028_implement_strstr.rs
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
/**
* [28] Implement strStr()
*
* Implement <a href="http://www.cplusplus.com/reference/cstring/strstr/" target="_blank">strStr()</a>.
*
* Return the index of the first occurrence of needle in haystack, or -1 if needle is not part of haystack.
*
* Example 1:
*
*
* Input: haystack = "hello", needle = "ll"
* Output: 2
*
*
* Example 2:
*
*
* Input: haystack = "aaaaa", needle = "bba"
* Output: -1
*
*
* Clarification:
*
* What should we return when needle is an empty string? This is a great question to ask during an interview.
*
* For the purpose of this problem, we will return 0 when needle is an empty string. This is consistent to C's <a href="http://www.cplusplus.com/reference/cstring/strstr/" target="_blank">strstr()</a> and Java's <a href="https://docs.oracle.com/javase/7/docs/api/java/lang/String.html#indexOf(java.lang.String)" target="_blank">indexOf()</a>.
*
*/
pub struct Solution {}
// submission codes start here
impl Solution {
pub fn str_str(haystack: String, needle: String) -> i32 {
if needle.is_empty() { return 0 }
haystack.find(&needle).map_or(-1_i32, |v| v as i32)
}
}
// submission codes end
#[cfg(test)]
mod tests {
use super::*;
#[test]
fn test_28() {
assert_eq!(Solution::str_str("hello".to_string(), "ll".to_string()), 2)
}
}