当前位置: 首页 > news >正文

做网站注册的商标类别自己创业做原公司一样的网站

做网站注册的商标类别,自己创业做原公司一样的网站,怎么找人做网站啊,杭州做网站怎么收费多少文章目录 前言牛客-寻找第K大、LeetCode215. 数组中的第K个最大元素【中等】题目及类型思路思路1:大顶堆思路2:快排二分随机基准点 前言 博主所有博客文件目录索引:博客目录索引(持续更新) 牛客-寻找第K大、LeetCode215. 数组中的第K个最大元…

文章目录

  • 前言
  • 牛客-寻找第K大、LeetCode215. 数组中的第K个最大元素【中等】
    • 题目及类型
    • 思路
      • 思路1:大顶堆
      • 思路2:快排+二分+随机基准点

前言

博主所有博客文件目录索引:博客目录索引(持续更新)


牛客-寻找第K大、LeetCode215. 数组中的第K个最大元素【中等】

题目及类型

相同题目:215. 数组中的第K个最大元素

题目链接:寻找第K大

题目内容:有一个整数数组,请你根据快速排序的思路,找出数组中第 k 大的数。给定一个整数数组 a ,同时给定它的大小n和要找的 k ,请返回第 k 大的数(包括重复的元素,不用去重),保证答案存在。

类型:大顶堆、快排+二分


思路

思路1:大顶堆

class Solution {public int findKthLargest(int[] nums, int k) {if (nums == null || nums.length == 0) {return 0;}PriorityQueue<Integer> queue = new PriorityQueue<>(k, (o1, o2)->o2.compareTo(o1));for (int i = 0; i < nums.length; i++) {queue.offer(nums[i]);}while (k > 1) {queue.poll();k--;}return queue.poll();}
}

思路2:快排+二分+随机基准点

最佳思路:快排+二分+随机基准点。在快排的过程中不断的找到对应的基准点,然后以这个基准点比较k(基准点的左边是>该基准点的,这样我们才能将基准点的索引与第k大的索引来进行比较)

思路:快排+二分+随机基准点

复杂度分析:

  • 时间复杂度:O(n.logn)
  • 空间复杂度:O(n)

一个探索思路的过程:

import java.util.*;public class Solution {private static int res;Private static Random random = new Ramdom();public int findKth(int[] a, int n, int K) {quickSort(a, 0, n - 1, K);return res;}public void quickSort(int[] a, int l, int r, int K) {if (l > r) {return;}int mid = partition(a, l, r);//看这个基准点与K的位置是否相符if (mid + 1 == K) {res = a[mid];}else if (mid + 1 < K) {quickSort(a, mid + 1, r, K);}else {quickSort(a, 0, mid - 1, K);}}public int partition(int[] a, int l, int r) {int x = Math.abs(random.nextInt()) % (r - l + 1) + l;swap(a, l, x);int j = l;for (int i = l + 1; i <= r; i++) {if (a[i] >= a[l]) {j++;swap(a, i, j);}}//交换基准点swap(a, l, j);return j;}public void swap(int[] arr, int i, int j) {int temp = arr[i];arr[i] = arr[j];arr[j] = temp;}}

不同的分块思路:

//方式一:
public int partition(int[] a, int l, int r) {int x = Math.abs(random.nextInt()) % (r - l + 1) + l;swap(a, l, x);int j = l;for (int i = l + 1; i <= r; i++) {if (a[i] >= a[l]) {j++;swap(a, i, j);}}//交换基准点swap(a, l, j);return j;
}//方式二:
public int partition(int[] a, int l, int r) {int v = a[l];int i = l + 1;int j = r;while (true) {//目标找到小于基准值的while (i <= r && a[i] > v ) {i++;}//目标找到大于基准值的//注意:这里j>=l+1while (j >= l + 1 && a[j] < v) {j--;}if (i > j) {break;}swap(a, i, j);i++;j--;}//交换基准点swap(a, l, j);return j;
}

写的好快排方式:

class Solution {//大顶堆找public int findKthLargest(int[] nums, int k) {//由于找的是第k大,那么从小到大的顺序就是kreturn quickFind(nums, 0, nums.length - 1, nums.length - k);}public int quickFind(int[] nums, int left, int right, int k) {//基准点int x = nums[left];if (left == right) return nums[k];int i = left - 1, j = right + 1;while (i < j) {do i ++; while (nums[i] < x);do j --; while (nums[j] > x);//交换if (i < j) {int tmp = nums[i];nums[i] = nums[j];nums[j] = tmp;}}//若是寻找的位置<=j,那么左范围进行递归if (k <= j) {return quickFind(nums, left, j, k);}else { //右范围进行递归return quickFind(nums, j + 1, right, k);}}}

image-20240115204027224


整理者:长路 时间:2024.1.14-15

http://www.yayakq.cn/news/171465/

相关文章:

  • 如何做网站卡密亚洲购物网站排名
  • 安徽省城乡建设厅网站在线网页代理器
  • 郑州的网站公司哪家好怎么建设网站后台
  • 定制程序网站沈阳网络平台推广公司
  • 在线手机动画网站模板太原网站建设公司哪家好
  • 蒙晟建设有限公司官方网站建筑工程施工合同电子版
  • 免费做试用的网站西地那非我吃了5年
  • 宁波做网站的公司做本地网站赚钱吗
  • 月牙河做网站公司小程序开发教程百度云
  • 网站这么上百度网站制作视频课程
  • 江西企业网站建设哪家好做断桥铝最知名的网站
  • 新增网站和新增接入怎样用腾讯云做网站
  • 滨州网站建设九鲁电视剧百度搜索风云榜
  • 互助县公司网站建设教育培训网站建设ppt
  • 建设个人网站ip中国制造网app官方下载
  • 英文外贸网站模板wordpress更改ip后登录
  • 建大型网站要多少钱怎么做外贸网站seo
  • 哪一个军事网站做的比较好怎么样引流顾客到店方法
  • 公司的网站建设费进入什么科目wordpress 科技
  • dw做的网站如何让文字换行企业搭建什么样的平台
  • 网站没制作好可以备案吗wordpress版权修改插件
  • 网站设计基本结构北戴河区建设局网站
  • 网站seo技术教程成全视频在线观看免费看
  • 比较好的做网站公司搜索引擎营销的主要模式有哪些?
  • 手机网站后台模板做智能网站软件
  • 平潭综合实验区建设局网站管理网站建设哪里好
  • ui图标素材网站长沙人才网官网
  • 我的个人博客网站开发板
  • 代理是干什么的西安百度seo排名软件
  • 西安宝马建设科技股份有限公司网站网站被挟持怎么办