查看: 938| 回复: 2
跳转到指定楼层
上一主题 下一主题
收起左侧

[Leetcode] 295. Find Median from Data Stream题test case过不了的原因

全局:

注册一亩三分地论坛,查看更多干货!

您需要 登录 才可以下载或查看附件。没有帐号?注册账号

x
请教大神,不知道17-22行哪里出了问题,总是取不到奇数情况的中间数,用的test case是
["MedianFinder","addNum","findMedian","addNum","findMedian","addNum","findMedian","addNum","findMedian","addNum","findMedian"][[],[-1],[],[-2],[],[-3],[],[-4],[],[-5],[]]

代码如下:
  1. class MedianFinder {
  2.     PriorityQueue<Integer> pq;
  3.     /** initialize your data structure here. */
  4.     public MedianFinder() {
  5.         pq = new PriorityQueue<>();
  6.     }
  7.    
  8.     public void addNum(int num) {
  9.         pq.add(num);
  10.     }
  11.    
  12.     public double findMedian() {
  13.         int n = pq.size();
  14.         double res = 0.0;
  15.         Iterator iter = pq.iterator();
  16.         Integer tmp = 0;
  17.         if (n % 2 != 0) {
  18.             for (int i = 0; i < n/2; i++) {
  19.                 iter.next();
  20.             }
  21.             tmp = (Integer) iter.next();
  22.             res = (double) tmp;
  23.         } else {
  24.             for (int i = 0; i < n/2; i++) {
  25.                 tmp = (Integer) iter.next();
  26.             }
  27.             Integer x = (Integer) iter.next();
  28.             res = ((double) tmp + (double) x)/2;
  29.         }
  30.         return res;
  31.     }
  32. }

  33. /**
  34. * Your MedianFinder object will be instantiated and called as such:
  35. * MedianFinder obj = new MedianFinder();
  36. * obj.addNum(num);
  37. * double param_2 = obj.findMedian();
  38. */
复制代码



上一篇:网上面试的话,公司用什么视频软件?加米
下一篇:美国公司OA中可以直接用库里面的算法吗
全局:
Java的pq iterator 不代表顺序,底层的结构是数组,只具有一定的堆序性,整体不算是有序的。

评分

参与人数 1大米 +1 收起 理由
小水 + 1 很有用的信息!

查看全部评分

回复

使用道具 举报

全局:
https://docs.oracle.com/javase/8.../PriorityQueue.html#iterator--


java.util
Class PriorityQueue&lt;E&gt;
...
public Iterator&lt;E&gt; iterator()
... The iterator does not return the elements in any particular order.


所以用priority queue + iterator在这里意义不大?

评分

参与人数 1大米 +1 收起 理由
小水 + 1 很有用的信息!

查看全部评分

回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册账号
隐私提醒:
  • ☑ 禁止发布广告,拉群,贴个人联系方式:找人请去🔗同学同事飞友,拉群请去🔗拉群结伴,广告请去🔗跳蚤市场,和 🔗租房广告|找室友
  • ☑ 论坛内容在发帖 30 分钟内可以编辑,过后则不能删帖。为防止被骚扰甚至人肉,不要公开留微信等联系方式,如有需求请以论坛私信方式发送。
  • ☑ 干货版块可免费使用 🔗超级匿名:面经(美国面经、中国面经、数科面经、PM面经),抖包袱(美国、中国)和录取汇报、定位选校版
  • ☑ 查阅全站 🔗各种匿名方法

本版积分规则

>
快速回复 返回顶部 返回列表