题解 | #在两个长度相等的排序数组中找到上中位数#
在两个长度相等的排序数组中找到上中位数
https://www.nowcoder.com/practice/6fbe70f3a51d44fa9395cfc49694404f
- 用哈希表存储原来的顺序,并且存储个数
- 遍历哈希表,感觉数据有点弱,数据是连在一起的,如果不是连在一起我感觉我这破烂代码wa了 Orz
- 判断条件看清楚就行,问题不大的
#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;
}
};