rustgym 0.2.0

rustgym solutions
Documentation
struct Solution;

use std::iter::FromIterator;

impl Solution {
    fn longest_palindrome(s: String) -> String {
        let n = s.len();
        if n == 0 {
            return "".to_string();
        }
        let s: Vec<char> = s.chars().collect();
        let mut start = 0;
        let mut end = 0;
        for i in 0..n {
            let mut left = i;
            let mut right = i;
            while right + 1 < n && s[right + 1] == s[left] {
                right += 1;
            }
            while left > 0 && right < n - 1 && s[left - 1] == s[right + 1] {
                left -= 1;
                right += 1;
            }
            if right - left > end - start {
                start = left;
                end = right;
            }
        }
        String::from_iter(&s[start..=end])
    }
}

#[test]
fn test() {
    let s = "babad".to_string();
    let res = "bab".to_string();
    assert_eq!(Solution::longest_palindrome(s), res);
}