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

    题目

    编程语言

    rust

    注意点

    去重条件 (i>0 && nums[i] == nums[i-1])

    rust 排序需要获得所有权,vec没有实现copy(trait)所以需要克隆

    rust vec.sort()的排序是稳定的,vec.sort_unstable()排序是不稳定的

    代码

    pub fn three_sum(nums: Vec<i32>) -> Vec<Vec<i32>> {
        let mut res:Vec<Vec<i32>> = Vec::new();
        if nums.len() < 3 {
            return res;
        }
        let mut nums2 = nums.clone();
        nums2.sort_unstable();
        if nums2[0] > 0 {
            return res;
        }
        for i in 0..(nums2.len()-2) {
            let target = -nums2[i];
            if i > 0 && nums2[i] == nums2[i-1] {
                continue;
            }
            let mut l = i+1;
            let mut r = nums2.len()-1;
            while l < r {
                let temp = nums2[l] + nums2[r];
                match temp.cmp(&target) {
                    std::cmp::Ordering::Equal => {
                        res.push(vec![-target,nums2[l],nums2[r]]);
                        while l < r && nums2[l] == nums2[l+1] {
                            l = l + 1;
                        }
                        while l < r && nums2[r] == nums2[r-1] {
                            r = r - 1;
                        }
                        l = l + 1;
                        r = r - 1;
                    },
                    std::cmp::Ordering::Less => {
                        l = l + 1
                    },
                    std::cmp::Ordering::Greater => {
                        r= r - 1
                    },
                }
            }
        }
        res
    }
    

    测试

    #[cfg(test)]
    mod tests{
        use super::*;
        #[test]
        fn test_1(){
            assert_eq!(three_sum(vec![-1,0,1,2,-1,-4]),vec![vec![-1,-1,2],vec![-1,0,1]]);
        }
        #[test]
        fn test_2(){
            assert_eq!(three_sum(vec![]),Vec::<Vec<i32>>::new());
        }
        #[test]
        fn test_3(){
            assert_eq!(three_sum(vec![0]),Vec::<Vec<i32>>::new());
        }
    }
    
  • 相关阅读:
    python之路-HTML初识
    python之路-CentOS6.5 安装Python 的依赖包
    python之路-离线pip下载Python包
    python之路-Memcache
    python之路-SQLAlchemy
    python之路-Redis
    python之路-Mysql
    偶然发现了获取有ID的dom的一种方法
    js 工厂模式和构造函数的区别
    ES6:export和import
  • 原文地址:https://www.cnblogs.com/GeniusOfCX/p/14630874.html
Copyright © 2011-2022 走看看