题解 | #在两个长度相等的排序数组中找到上中位数#

在两个长度相等的排序数组中找到上中位数

https://www.nowcoder.com/practice/6fbe70f3a51d44fa9395cfc49694404f

  1. 用哈希表存储原来的顺序,并且存储个数
  2. 遍历哈希表,感觉数据有点弱,数据是连在一起的,如果不是连在一起我感觉我这破烂代码wa了 Orz
  3. 判断条件看清楚就行,问题不大的

#include <cstdio>
#include <unordered_map>
class Solution {
public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * find median in two sorted array
     * @param arr1 int整型vector the array1
     * @param arr2 int整型vector the array2
     * @return int整型
     */
    int findMedianinTwoSortedAray(vector<int>& arr1, vector<int>& arr2) {
        // write code here
        unordered_map<int, int> mp;
        int maxn = 0;

        for (int i : arr1)
        {
            mp[i] ++;
            maxn = max(maxn, i);
        }
        for (int i : arr2)
        {
            mp[i] ++;
            maxn = max(maxn, i);
        }
        
        int m = arr1.size() + arr2.size(), k;
        if(m % 1)
        {
            k = m / 2 + 1;
        }
        else k = m / 2;

        for (int i = 0; i < maxn; i ++)
        {   
            //cout << i << ' ' << mp[i] << ' ' << k << endl; 1 2 3 3 4 4 5 6
            if(k - mp[i] == 0) return i;
            else if (k - mp[i] < 0) return i - 1;
            else k -= mp[i]; 
        }
        return 0;
    }
};

全部评论

相关推荐

昨天 16:55
已编辑
北京工业大学 Java
211本,找日常实习的话,如果面向中厂的话,需要刷hot100么?因为之前从来没刷过,算法仅限于学校课程水平,准备3月投递简历,现在还需要背八股文,时间有些紧张,还需要刷算法题么?同时什么样的公司可以算是中厂呢?
程序员小白条:中大厂说的上名字的,必定要算法,hot100只是最基础的了,题库远不止100题捏,一般在300-400题量之间,算法=学校课程=简单题也做不出,多准备八股文和算法吧,其他项目可以放放,精刷算法就行了,花时间成长很快的
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务