用 Rust 刷 leetcode 第四题

Problem

There are two sorted arrays nums1 and nums2 of size m and n respectively.

Find the median of the two sorted arrays. The overall run time complexity should be O(log (m+n)).

You may assume nums1 and nums2 cannot be both empty.

Example

Example 1:
nums1 = [1, 3]
nums2 = [2]
The median is 2.0

Example 2:
nums1 = [1, 2]
nums2 = [3, 4]
The median is (2 + 3)/2 = 2.5

Solution

use std::cmp::max;
use std::cmp::min;
pub fn find_median(nums1: Vec<i32>, nums2: Vec<i32>) -> f64 {
    let n = nums1.len();
    let m = nums2.len();
        
    let mut l1 = 0;
    let mut l2 = 0;
    let mut r1 = 0;
    let mut r2 = 0;
    let mut c1: usize = 0;
    let mut c2: usize = 0;
    let mut lo: usize = 0;
    let mut hi: usize = 2*n;
        
    while lo <= hi { //此处就是为什么要先让数组1最短的原因
        c1 = (lo + hi)/2;
        c2 = m + n - c1;
        l1 = if (c1 == 0) {
            std::i32::MIN
        } else {
            nums1[(c1-1)/2]
        };
            
        r1 = if c1 == 2*n {
            std::i32::MAX  
        } else {
            nums1[c1/2]  
        };
            
        l2 = if (c2 == 0) {
            std::i32::MIN
        } else {
            nums2[(c2-1)/2]
        };
            
        r2 = if c2 == 2*m {
            std::i32::MAX  
        } else {
            nums2[c2/2]  
        };
            
        if l1 > r2 {
            hi = c1 - 1;
        } else if l2 > r1 {
            lo = c1 + 1;
        } else {
            break;
        }
    }
        
    ((max(l1, l2) + min(r1, r2)) as f64) / 2.0
}

impl Solution {   
    pub fn find_median_sorted_arrays(nums1: Vec<i32>, nums2: Vec<i32>) -> f64 {
        let n = nums1.len();
        let m = nums2.len();
        
        if n > m {
            find_median(nums2, nums1)
        } else {
            find_median(nums1, nums2)
        }
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值