📣 独立日限时特惠: VIP通行证立减$68
查看: 2136| 回复: 4
跳转到指定楼层
上一主题 下一主题
收起左侧

[Leetcode] 求助Kth Largest Element in an Array

全局:

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

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

x
下面是我在网上找的能accept的代码.我想不通的是下面这段:

        else if (pivot + 1 > k)
        {
            return select(nums, k, left, pivot - 1);
        }
        else
        {
            return select(nums, k, pivot + 1, right);
        }



举例子,数组是[3, 2, 1, 5, 6, 4],
假设用3做partition, 那么数组变为
[5, 6, 4]  3 [2, 1]
当k = 3时,pivot + 1 > k,也就是说在[5, 6, 4] 找第3大的数,这个正确
但是,当k=5时,pivot + 1 < k, select(nums, k, pivot + 1, right);按照代码,就是要在[2, 1]里继续找第5大的数,我就很不明白了,不是应该在[2, 1]里继续找第k - pivot - 1 = 1大的数吗?为什么还是继续找第5大的数.
但是,代码在leetcode里却能跑过,而改成return select(nums, k - pivot - 1, pivot + 1, right);却报stack overflow...

===================
public class Solution
{
    public int findKthLargest(int[] nums, int k)
    {
        return select(nums, k, 0, nums.length - 1);
    }

    int partition(int[] data, int l, int r)
    {
        int left = l;
        int right = r;
        int pivot = data[left];

        while (left < right)
        {
            while (left < right && data[right] <= pivot)
            {
                right--;
            }
            
            data[left] = data[right];

            while (left < right && data[left] >= pivot)
            {
                left++;
            }

            data[right] = data[left];
        }

        data[left] = pivot;
        return left;
    }

    private int select(int[] nums, int k, int left, int right)
    {
        int pivot = partition(nums, left, right);

        if (pivot + 1 == k)
        {
            return nums[pivot];
        }
        else if (pivot + 1 > k)
        {
            return select(nums, k, left, pivot - 1);
        }
        else
        {
            return select(nums, k, pivot + 1, right);
        }
    }
}

===================







上一篇:寒假有转专业的小伙伴一起学习JAVA刷题吗!
下一篇:有没有一起刷题的小伙伴
🔗
hot2346 2016-12-29 03:24:57 | 只看该作者
全局:
你看递归结束的条件, 肯定不是 k==1的时候结束, 估计是  lft == k
回复

使用道具 举报

🔗
 楼主| huangyingw 2016-12-29 06:24:02 | 只看该作者
全局:
hot2346 发表于 2016-12-29 03:24
你看递归结束的条件, 肯定不是 k==1的时候结束, 估计是  lft == k

多谢指点..字数字数..
回复

使用道具 举报

🔗
chaosMonkey 2017-1-3 14:43:07 | 只看该作者
全局:
这个和在bst中找第k大的数是不一样的
回复

使用道具 举报

🔗
donnice 2017-1-3 14:59:17 | 只看该作者
全局:
它依旧是在原数组里找出第5大的数,但已经把范围缩小到了[2,1],并不是说在新的数组里找出第k大的数
回复

使用道具 举报

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

本版积分规则

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