zoukankan      html  css  js  c++  java
  • leetcode 81 rust

    题目

    编程语言

    rust

    注意点

    二分法和33题相似,仅当有数字重复时进行不同的判断

    代码

    pub fn search(nums: Vec<i32>, target: i32) -> bool {
        let mut left = 0_i32;
        let mut right = (nums.len() as i32) - 1;
        let mut mid;
        while left <= right {
            mid = left + ((right - left) >> 1);
            if nums[mid as usize] == target {
                return true;
            }
            // nums[left] == nums[mid] 意味着从nums[mid]到nums[right]到nums[left]的值都相等
            if nums[mid as usize] == nums[left as usize] {
                left += 1;
                continue;
            }
            match nums[mid as usize].cmp(&nums[left as usize]) {
                // left和mid 落在同一数组中
                std::cmp::Ordering::Greater | std::cmp::Ordering::Equal => {
                    // left,mid,right,target在同一数组中
                    if nums[mid as usize] > target && target >= nums[left as usize] {
                        right = mid - 1;
                    // target落在mid和right中间
                    }else if nums[mid as usize] < target || target < nums[left as usize] {
                        left = mid + 1;
                    }
                },
                // left和mid 落在两个数组中
                std::cmp::Ordering::Less => {
                    // left,mid,right,target在同一数组中
                    if nums[mid as usize] < target && target <= nums[right as usize] {
                        left = mid + 1;
                    // target落在left和mid中间
                    }else if nums[mid as usize] > target || target > nums[right as usize] {
                        right = mid - 1;
                    }
                },
            }
        }
        false
    }
    

    测试

    #[cfg(test)]
    mod tests{
        use super::*;
        #[test]
        fn test_exist(){
            assert_eq!(search(vec![2,5,6,0,0,1,2],0),true);
        }
        #[test]
        fn test_not_exist(){
            assert_eq!(search(vec![2,5,6,0,0,1,2],3),false);
        }
        #[test]
        fn test_null(){
            assert_eq!(search(vec![1],0),false);
        }
    }
    
  • 相关阅读:
    trap命令
    MySQL数据库中日期中包涵零值的问题
    MySQL锁等待分析【2】
    MySQL锁等待分析【1】
    mysql日志文件相关的配置【2】
    mysql日志文件相关的配置【1】
    Linux的标准输出、标准错误输出、nohup
    mysql在关闭时的几个阶段
    MHA环境搭建【4】manager相关依赖的解决
    keepalived+httpd 做web服务的高可用
  • 原文地址:https://www.cnblogs.com/GeniusOfCX/p/14605980.html
Copyright © 2011-2022 走看看