随笔 - 165,  文章 - 0,  评论 - 4,  阅读 - 18023

题目:

class MedianFinder {      //暴力解法:每添加一个数字后用sort进行排序,然后返回中位数,时间复杂度:nlogn,会超时。因此采用**二分法查找并进行插入的方法**。时间复杂度:logn
public:
    vector<int> nums;      //初始化一个当前数组
    /** initialize your data structure here. */
    MedianFinder() {
        
    }
    
    void addNum(int num) {
        if(nums.empty()){
            nums.push_back(num);      //当前数组为空则直接插入数字
        }
        else{
            nums.insert(lower_bound(nums.begin(), nums.end(), num), num);      //当前数组不为空:利用lower_bound(),在nums.begin()和nums.end()中的前闭后开区间进行二分查找,返回大于或等于num的第一个元素位置。然后在该位
        }                                                                                                                                                                                            //置插入num
    }
    
    double findMedian() {
        int n = nums.size();
        return n%2==1 ? nums[n/2] : (nums[n/2-1]+nums[n/2])*0.5;      //按要求返回中位数。要注意的是如果数组为偶数的话,返回中间两个数的平均数时要用*0.5,不能用/2,否则小数部分会被省略
    }
};

作者:腐烂的橘子
链接:https://leetcode.cn/problems/shu-ju-liu-zhong-de-zhong-wei-shu-lcof/solutions/104353/you-xian-dui-lie-by-z1m/
来源:力扣(LeetCode)

posted on   孜孜不倦fly  阅读(3)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· AI 智能体引爆开源社区「GitHub 热点速览」
· Manus的开源复刻OpenManus初探
· 写一个简单的SQL生成工具

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
点击右上角即可分享
微信分享提示