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

湛江免费做网站网络营销外包网络推广

湛江免费做网站,网络营销外包网络推广,建大网站首页,企业服务账号怎么查询仓库管理员以数组 stock 形式记录商品库存表,其中 stock[i] 表示对应商品库存余量。请返回库存余量最少的 cnt 个商品余量,返回 顺序不限。 示例 1: 输入:stock [2,5,7,4], cnt 1 输出:[2]示例 2: 输入…

仓库管理员以数组 stock 形式记录商品库存表,其中 stock[i] 表示对应商品库存余量。请返回库存余量最少的 cnt 个商品余量,返回 顺序不限

示例 1:

输入:stock = [2,5,7,4], cnt = 1
输出:[2]

示例 2:

输入:stock = [0,2,3,6], cnt = 2
输出:[0,2] 或 [2,0]

LCR 159. 库存管理 III - 力扣(LeetCode)

首先考虑用TreeSet来实现这个代码,因为TreeSet会基于红黑树自动帮我们排序。

class Solution {public int[] inventoryManagement(int[] stock, int cnt) {TreeSet<Integer> treeSet = new TreeSet<>();for(int i = 0; i < stock.length; i++){treeSet.add(stock[i]);}// 取出最小的 cnt 个元素int[] result = new int[cnt];int index = 0;for (int num : treeSet) {if (index < cnt) {result[index++] = num;} else {break; // 已经取够 cnt 个元素,退出循环}}return result;}
}

很明显,不合适,因为Set集合会去重。

下面改用快排,快排的时间复杂度为O(n),刚好复习一下快排的代码。

class Solution {public int[] inventoryManagement(int[] stock, int cnt) {quickSort(stock, 0, stock.length - 1);int[] result = new int[cnt];for(int i = 0; i < cnt; i++){result[i] = stock[i];}return result;}public void quickSort(int[] stock, int low, int high){if (low < high) {// 找到分区点int partitionIndex = partition(stock, low, high);// 递归排序左半部分quickSort(stock, low, partitionIndex - 1);// 递归排序右半部分quickSort(stock, partitionIndex + 1, high);}}public int partition(int[] stock, int low, int high){//找到基准元素int pivot = stock[low];int left = low + 1;   //左指针int right = high;  //右指针while(left <= right){while(left <= right && stock[right] > pivot){right--;}while(left <= right && stock[left] < pivot){left++;}if(left <= right){swap(stock,left,right);left++;right--;}}swap(stock,right,low);return right;}private void swap(int[] stock, int i, int j) {int temp = stock[i];stock[i] = stock[j];stock[j] = temp;}}

快排的核心全在partition算法里,本质是确定分区点,每一次分区就代表这个元素被排好了。

我们分析一下改怎么写,如何确定最后return的是左边还是右边。

我们把最左端定为哨兵,也就是说最后的位置左边必须比哨兵小,右边必须比哨兵大。while循环的条件是left<=right。首先收缩边界,然后交换,最后的情况是right指着最后一个小于或等于 pivot 的元素。因此要pivot和right换。

http://www.dtcms.com/wzjs/44651.html

相关文章:

  • wordpress 文章收缩seo关键词推广方式
  • 网站建设硬件seo技术自学
  • 苏州网站建立公司宁德市
  • 北京网站开发建设 58同城中国500强最新排名
  • 做to b的网站推广公司简介
  • 有关于网站建设的论文百度精准推广
  • 简单做网站用什么软件广东省自然资源厅
  • 做网站配送地址怎么变换淄博百度推广
  • 免费英文 网站模板万网域名注册查询
  • 合肥网站制作价格广州seo网络优化公司
  • 中山移动网站建设公司产品怎么做推广和宣传
  • 自己做网站的方法seo联盟
  • 广州电商网站开发网店seo名词解释
  • 淮南网站制作艾滋病多长时间能查出来
  • asp 网站建设教程济南seo优化公司助力网站腾飞
  • 西安做网站建设的郑州做网站的专业公司
  • 剖析材料范文哪个网站做的好查网站权重
  • wap手机网站模板百度优化是什么
  • 做h动漫的动漫视频在线观看网站充电宝seo关键词优化
  • 企业培训 电子商务网站建设 图片电脑版百度入口
  • 做果蔬行业的网站智能营销系统
  • 响应式网站建设信息制作网站建设入门
  • 一些网站只能在微信打开怎么做的什么是互联网营销
  • 做一个赚钱的网站什么是seo文章
  • 湖南住房和城乡建设厅网站首页互联网推广运营
  • 十大黑心装修公司北京seo运营
  • 云南楚雄天气预报黄山seo公司
  • 长沙网站制作公司有哪些营销策划公司
  • html如果制作一个内容多的网站外贸网站优化公司
  • 全flash网站制作seo平台