算法_第k大的数_快排(leetcode215,java)

简介: 算法_第k大的数_快排(leetcode215,java)

前言

1.(Math.random()(x-y))+y // Math.random()(x-y+1)+y; 随机数x~y

2.递归

3.三目运算法则

4.快排模板

void quick_sort(int q[], int l, int r)
{
    if (l >= r) return;
    int i = l - 1, j = r + 1, x = q[l + r >> 1];
    while (i < j)
    {
        do i ++ ; while (q[i] < x);
        do j -- ; while (q[j] > x);
        if (i < j) swap(q[i], q[j]);
    }
    quick_sort(q, l, j), quick_sort(q, j + 1, r);
}
作者:yxc
链接:https://www.acwing.com/blog/content/277/
来源:AcWing


一、题目描述

给定整数数组 nums 和整数 k,请返回数组中第 k 个最大的元素。

请注意,你需要找的是数组排序后的第 k 个最大的元素,而不是第 k 个不同的元素。

示例 1:

输入: [3,2,1,5,6,4] 和 k = 2

输出: 5


示例 2:

输入: [3,2,3,1,2,4,5,5,6] 和 k = 4

输出: 4


提示:

1 <= k <= nums.length <= 104

-104 <= nums[i] <= 104


二、思路

目标寻找第k大的数,所以可以利用快排(快排基础就不细说了,可以自己去了解一下),这些数不一定排好,标准数左边是大数,右边是小数,然后再在左边大数中寻找目标数,如果此时标准数刚刚好是所求下标(在数组中是k-1),则即为所求值。


三、代码实现

代码如下(示例):

class Solution {
    public int findKthLargest(int[] nums, int k) {
  return QuickSort(nums,0,nums.length-1,k);
  }
  public int QuickSort(int nums[],int l,int r,int k)
  {
    int index = randomParam(nums, l, r);
    if(index == k-1)
    {
      return nums[index];
    }else{
      return index>k-1?  QuickSort(nums,l,index-1,k): QuickSort(nums,index+1,r,k); 
    }
  }
  public int randomParam(int nums[],int l,int r)
  {
    int b = (int)(Math.random()*(r-l+1)+l);
    swap(nums,b,r);
    return quick_sort(nums,l,r);
  }
  public int quick_sort(int nums[],int l,int r)
  { // 可以记住这个模板,把基准数默认放到最右边,然后开始左右指针移动比较
  //这里没有用那个do_while模板,那个容易超过时间限制
    int c = r;
    int index = nums[r];
    while(l<r)
    {
      while(l<r && nums[l] > index) l++;
      while(l<r && nums[r] <= index) r--; 
      if(l<r) 
                swap(nums,l,r);
    }
    swap(nums,l,c);
    return l;
  }
  public void swap(int [] nums,int l, int r)
  {
    int temp = nums[l];
    nums[l] = nums[r];
    nums[r] = temp;
  }
}


相关文章
|
2月前
|
存储 人工智能 算法
数据结构与算法细节篇之最短路径问题:Dijkstra和Floyd算法详细描述,java语言实现。
这篇文章详细介绍了Dijkstra和Floyd算法,这两种算法分别用于解决单源和多源最短路径问题,并且提供了Java语言的实现代码。
91 3
数据结构与算法细节篇之最短路径问题:Dijkstra和Floyd算法详细描述,java语言实现。
|
2月前
|
算法
Leetcode 初级算法 --- 数组篇
Leetcode 初级算法 --- 数组篇
41 0
|
1月前
|
存储 算法 Java
leetcode算法题-有效的括号(简单)
【11月更文挑战第5天】本文介绍了 LeetCode 上“有效的括号”这道题的解法。题目要求判断一个只包含括号字符的字符串是否有效。有效字符串需满足左括号必须用相同类型的右括号闭合,并且左括号必须以正确的顺序闭合。解题思路是使用栈数据结构,遍历字符串时将左括号压入栈中,遇到右括号时检查栈顶元素是否匹配。最后根据栈是否为空来判断字符串中的括号是否有效。示例代码包括 Python 和 Java 版本。
|
2月前
|
算法
每日一道算法题(Leetcode 20)
每日一道算法题(Leetcode 20)
29 2
|
2月前
|
算法 搜索推荐 Java
java 后端 使用 Graphics2D 制作海报,画echarts图,带工具类,各种细节:如头像切割成圆形,文字换行算法(完美实验success),解决画上文字、图片后不清晰问题
这篇文章介绍了如何使用Java后端技术,结合Graphics2D和Echarts等工具,生成包含个性化信息和图表的海报,并提供了详细的代码实现和GitHub项目链接。
141 0
java 后端 使用 Graphics2D 制作海报,画echarts图,带工具类,各种细节:如头像切割成圆形,文字换行算法(完美实验success),解决画上文字、图片后不清晰问题
|
2月前
|
算法 Java 数据中心
探讨面试常见问题雪花算法、时钟回拨问题,java中优雅的实现方式
【10月更文挑战第2天】在大数据量系统中,分布式ID生成是一个关键问题。为了保证在分布式环境下生成的ID唯一、有序且高效,业界提出了多种解决方案,其中雪花算法(Snowflake Algorithm)是一种广泛应用的分布式ID生成算法。本文将详细介绍雪花算法的原理、实现及其处理时钟回拨问题的方法,并提供Java代码示例。
89 2
|
2月前
|
算法 Java Linux
java制作海报一:java使用Graphics2D 在图片上写字,文字换行算法详解
这篇文章介绍了如何在Java中使用Graphics2D在图片上绘制文字,并实现自动换行的功能。
141 0
|
2月前
|
算法 Java
LeetCode(一)Java
LeetCode(一)Java
|
2月前
|
算法 Java 测试技术
数据结构 —— Java自定义代码实现顺序表,包含测试用例以及ArrayList的使用以及相关算法题
文章详细介绍了如何用Java自定义实现一个顺序表类,包括插入、删除、获取数据元素、求数据个数等功能,并对顺序表进行了测试,最后还提及了Java中自带的顺序表实现类ArrayList。
31 0
|
4月前
|
设计模式 缓存 算法
揭秘策略模式:如何用Java设计模式轻松切换算法?
【8月更文挑战第30天】设计模式是解决软件开发中特定问题的可重用方案。其中,策略模式是一种常用的行为型模式,允许在运行时选择算法行为。它通过定义一系列可互换的算法来封装具体的实现,使算法的变化与客户端分离。例如,在电商系统中,可以通过定义 `DiscountStrategy` 接口和多种折扣策略类(如 `FidelityDiscount`、`BulkDiscount` 和 `NoDiscount`),在运行时动态切换不同的折扣逻辑。这样,`ShoppingCart` 类无需关心具体折扣计算细节,只需设置不同的策略即可实现灵活的价格计算,符合开闭原则并提高代码的可维护性和扩展性。
67 2