mirror of https://github.com/01-edu/public.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
davhojt
5f935e29a8
|
3 years ago | |
---|---|---|
.. | ||
README.md | 3 years ago |
README.md
string literals
Instructions
Create the following functions:
is_empty
: that returnstrue
if the string is empty.is_ascii
: that returnstrue
if all characters are within the ASCII range.contains
: that returnstrue
if the string contains the given pattern.split_at
: that divides a string in two returning a tuple.find
: that returns the index of the first character of a given string that matches the pattern.
Expected functions
pub fn is_empty(v: &str) -> bool {
}
pub fn is_ascii(v: &str) -> bool {
}
pub fn contains(v: &str, pat: &str) -> bool {
}
pub fn split_at(v: &str, index: usize) -> (&str, &str) {
}
pub fn find(v: &str, pat: char) -> usize {
}
Your heap allocations will be monitored to ensure that you do not make too many allocations, and that your allocations are reasonably sized.
Usage
Here is a program to test your function
use string_literals::*;
fn main() {
println!("{}", is_empty(""));
println!("{}", is_ascii("rust"));
println!("{}", contains("rust", "ru"));
println!("{:?}", split_at("rust", 2));
println!("{}", find("rust", 'u'));
}
And its output
$ cargo run
true
true
true
("ru", "st")
1
$