从数组中找出第K大的数
利用改进的快排方法
public class QuickFindMaxKValue {
public static void main(String[] args) {
int[] a = {8, 3, 4, 1, 9, 7, 6, 10, 2, 5};
System.out.println(findMaxValue(a, 0, a.length - 1, 2));
}
private static int findMaxValue(int[] a, int lo, int hi, int maxValueIndex) {
if (lo >= hi) {
return -1;
}
if (maxValueIndex == a.length) {
return a[maxValueIndex];
}
int pivot = partition(a, lo, hi);
if (maxValueIndex < pivot) {
return findMaxValue(a, lo, pivot - 1, maxValueIndex);
} else if (maxValueIndex > pivot) {
return findMaxValue(a, pivot + 1, hi, maxValueIndex);
}
return pivot;
}
private static int partition(int[] a, int lo, int hi) {
int mid = (lo + hi) / 2;
if (a[mid] > a[hi]) {
swapValue(a, mid, hi);
}
if (a[lo] > a[hi]) {
swapValue(a, lo, hi);
}
if (a[lo] > a[mid]) {
swapValue(a, lo, mid);
}
int key = a[lo];
while (lo < hi) {
while (lo < hi && a[hi] > key) {
hi--;
}
a[lo] = a[hi];
while (lo < hi && a[lo] < key) {
lo++;
}
a[hi] = a[lo];
}
a[lo] = key;
return lo;
}
private static void swapValue(int[] a, int left, int right) {
if (left == right) {
return;
}
int temp = a[left];
a[left] = a[right];
a[right] = temp;
}
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!