寻找两个正序数组的中位数

题目链接:https://leetcode-cn.com/problems/median-of-two-sorted-arrays/
题目描述:

题解:

class Solution {
public:
    double findMedianSortedArrays(vector<int>& nums1, vector<int>& nums2) {
        
        double ans = 0;
        int len = nums1.size() + nums2.size();
        if(len % 2 == 0)
            ans = (getNum(nums1, nums2, len / 2 - 1) + getNum(nums1, nums2, len / 2)) / 2;
        else
            ans = getNum(nums1, nums2, len / 2);
        return ans;

    }

    //归并排序
    double getNum(vector<int>& nums1, vector<int>& nums2, int k)
    {
        vector<int> result(nums1.size() + nums2.size(), -1);
        int i = 0, j = 0;
        int cur = 0;
        while( i < nums1.size() && j < nums2.size() && cur <= k)
        {
            if(nums1[i] < nums2[j])
                result[cur++] = nums1[i++];
            else
                result[cur++] = nums2[j++];

        }
        while(i < nums1.size() && cur <= k)
            result[cur++] = nums1[i++];
        while(j < nums2.size() && cur <= k)
            result[cur++] = nums2[j++];
        return result[cur - 1];
    }
};
posted @   张宵  阅读(31)  评论(0编辑  收藏  举报
编辑推荐:
· Linux glibc自带哈希表的用例及性能测试
· 深入理解 Mybatis 分库分表执行原理
· 如何打造一个高并发系统?
· .NET Core GC压缩(compact_phase)底层原理浅谈
· 现代计算机视觉入门之:什么是图片特征编码
阅读排行:
· 手把手教你在本地部署DeepSeek R1,搭建web-ui ,建议收藏!
· Spring AI + Ollama 实现 deepseek-r1 的API服务和调用
· 数据库服务器 SQL Server 版本升级公告
· 程序员常用高效实用工具推荐,办公效率提升利器!
· C#/.NET/.NET Core技术前沿周刊 | 第 23 期(2025年1.20-1.26)
点击右上角即可分享
微信分享提示