rustgym 0.2.0

rustgym solutions
Documentation
struct Solution;

impl Solution {
    fn search(nums: Vec<i32>, target: i32) -> i32 {
        let n = nums.len();
        let mut l: i32 = 0;
        let mut r: i32 = n as i32 - 1;
        while l <= r {
            let m = (l + r) / 2;
            if target == nums[m as usize] {
                return m as i32;
            } else if nums[l as usize] <= nums[m as usize] {
                if nums[l as usize] <= target && target <= nums[m as usize] {
                    r = m - 1;
                } else {
                    l = m + 1;
                }
            } else {
                if nums[m as usize] <= target && target <= nums[r as usize] {
                    l = m + 1;
                } else {
                    r = m - 1;
                }
            }
        }
        -1
    }
}

#[test]
fn test() {
    let nums = vec![4, 5, 6, 7, 0, 1, 2];
    let target = 0;
    assert_eq!(Solution::search(nums, target), 4);
    let nums = vec![4, 5, 6, 7, 0, 1, 2];
    let target = 3;
    assert_eq!(Solution::search(nums, target), -1);
    let nums = vec![3, 5, 1];
    let target = 3;
    assert_eq!(Solution::search(nums, target), 0);
    let nums = vec![4, 5, 6, 7, 8, 1, 2, 3];
    let target = 8;
    assert_eq!(Solution::search(nums, target), 4);
}