题目:如何得到一个数据流中的中位数?如果从数据流中读出奇数个数值,那么中位数就是所有数值排序之后位于中间的数值。如果从数据流中读出偶数个数值,那么中位数就是所有数值排序之后中间两个数的平均值。我们使用Insert()方法读取数据流,使用GetMedian()方法获取当前读取数据的中位数。
1.将数据流加入数据结构中
可以在类中创建一个成员变量 vector temp,因为类中的成员函数可以访问成员变量,所有数据流读取函数Insert即便没有返回值也没有引用数组,依然可以将数据读入数据结构。
2.找到中位数
先将数组进行排序,位置中间的数自然是中位数了。
class Solution {
public:
vector<int> temp;
void Insert(int num