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

网站设计 三把火科技网上购物网站开发背景

网站设计 三把火科技,网上购物网站开发背景,公网站建设,网站宣传推广前言 🌟🌟本期讲解关于力扣的几篇题解的详细介绍~~~ 🌈感兴趣的小伙伴看一看小编主页:GGBondlctrl-CSDN博客 🔥 你的点赞就是小编不断更新的最大动力 🎆那么废话不…

前言

🌟🌟本期讲解关于力扣的几篇题解的详细介绍~~~

🌈感兴趣的小伙伴看一看小编主页:GGBondlctrl-CSDN博客

🔥 你的点赞就是小编不断更新的最大动力                                       

🎆那么废话不多说直接开整吧~~

目录

📚️1.颜色分类

🚀1.1题目分析

🚀1.2思路分析

🚀1.3代码实现

📚️2.数组排序(双重解法)

🚀2.1题目分析

🚀2.2思路分析

2.2.1分治思想

2.3.2分治并归

🚀2.3代码实现

2.3.1分治思想 

2.3.2分治并归

📚️3.数组中第K个最大元素

🚀3.1题目分析

🚀3.2思路分析

3.2.1建立小根堆

3.2.2分治思想

🚀3.3代码实现

3.3.1建立小根堆思想

3.3.2分治思想

📚️4.总结

📚️1.颜色分类

🚀1.1题目分析

给定一个包含红色、白色和蓝色、共 n 个元素的数组 nums ,原地 对它们进行排序,使得相同颜色的元素相邻,并按照红色、白色、蓝色顺序排列。

我们使用整数 0、 1 和 2 分别表示红色、白色和蓝色。

    必须在不使用库内置的 sort 函数的情况下解决这个问题。

    所以换一句话总结来说,就是将这里的数组进行排序,相邻的数字挨在一起;

     

    即如上图所示;

    🚀1.2思路分析

    这不就简单了吗,哈哈哈,小编的思路如下所示;

    第一种:直接通过八大排序,随便取一种进行排序即可;

    第二种:通过模拟哈希的方式,记录0下标有几个数,然后1下标有几个数,2下标有几个                      数,最后循环遍历输出就可以了;

    第三种:就是我们以分治的思想,将整个数组拆成三份;

     当然小编本期讲解的就是第三种思想方法;

    具体是思路:

    我们将数组分成三份,第一部分就是小于1的,第二部分就是等于1的,第三部分就是大于1的;

    那么使用双指针,分别在左右两端,指针i负责遍历数组,那么如果出现0就与left进行交换,1就直接跳过,2就与right进行交换;

    图示如下:

    注意:在这里我们为啥在num[ i ] 大于1后,为啥交换后,i不用增加呢?其实我们并不知道right指针所指的值,那么交换到i指针位置后,所以i指针需要继续进行判断;

    核心:

    num[ i ] < 1:left++,交换,i++;

    num[ i ] ==1:  i++;

    num[ i ] > 1:  right--,交换 

    🚀1.3代码实现

    代码如下所示:

    class Solution {public void sortColors(int[] nums) {int left = -1;int right = nums.length;for(int i = 0; i < right;){if(nums[i] == 0){swap(nums,++left,i);i++;}else if(nums[i] == 2){swap(nums,--right,i);}else{i++;}}}public void swap(int[] nums,int left,int right){int temp = nums[left];nums[left] = nums[right];nums[right] = temp;}
    }

    解释:注意这里的跳出循环条件,和初始化left与right的值,以及对于数组来说,这里的交换是如何进行的;

    📚️2.数组排序(双重解法)

    🚀2.1题目分析

    其实看题目就知道,这里就是对于数组进行排序的操作,如下所示:

    OK小编也不再多说了,直接进行入正题

    🚀2.2思路分析

    2.2.1分治思想

    其实这里的思路和上面进行分治的操作的思想是一致,将原始的数组进行分治三份进行后,元素就分为三个部分,其中等于某一个key值后,我们就不用管这个等于key的部分了,左边都是小于key的,右边都是大于key的,那么我们再对于这两个部分进行分治的操作;

    一直进行分治操作下,若只剩下两个数字,那么分治过后必定是有序的;那么总结:

    在不断的分治过程中,等于key的部分不用管,那么不等于key的两边部分一直进行分治操作,那么最终就会变得有序;

     

    那么这就是分治分三块思想可以完成次题的具体步骤;

    2.3.2分治并归

    这里的操作其实其实小编在很早的时候就已经讲解过了,就是快排的思想;

    不断的拆分,直到为一个数字的时候进行合并的操作,这里的合并的操作就是比较重要的;在每次合并的时候进行排序,那么在最终合成后,整个数组就是一个有序的数组;

    那么最终就是如上图所示,即可完成本此的排序操作;

    🚀2.3代码实现

    2.3.1分治思想 

    代码如下所示:

    class Solution {public int[] sortArray(int[] nums) {qsort(nums, 0 ,nums.length - 1);return nums;}public void qsort(int nums[],int l,int r){if(l>=r){return;}//随机进行取值的操作int key = nums[new Random().nextInt(r - l + 1) + l];int left = l - 1;int right = r + 1;int i = l;//进行三块分类排序的操作while(i < right){if(nums[i] < key){left++;swap(nums,i,left);i++;}else if(nums[i] == key){i++;}else if(nums[i] > key){right--;swap(nums,i,right);}}//排序完成后分为三部分[l,left][left+1,right-1][right,r]qsort(nums,l,left);qsort(nums,right,r);}public void swap(int nums[],int left,int right){int temp = nums[left];nums[left] = nums[right];nums[right] = temp;}
    }

    注意:这里的交换条件,以及边界的情况;

    2.3.2分治并归

    代码如下所示:

    class Solution {public int[] sortArray(int[] nums) {//归并排序操作mergeSort(nums,0,nums.length - 1);return nums;  }public void mergeSort(int[] nums,int left,int right){//进行边界判断if(left >= right){return;}//获取中点int mid = (right + left)/2;//此时[left,mid][mid + 1,right]mergeSort(nums,left,mid);mergeSort(nums,mid + 1 ,right);int[] temp = new int[right - left + 1];//合并数据操作int cur1 = left;int cur2 = mid + 1;int i = 0;while(cur1 <= mid && cur2 <= right){if(nums[cur1] <= nums[cur2]){temp[i] = nums[cur1];i++;cur1++;}else{temp[i] = nums[cur2];i++;cur2++;}}//判断是否还存在元素while(cur1 <= mid){temp[i] = nums[cur1];i++;cur1++;}while(cur2 <= right){temp[i] = nums[cur2];i++;cur2++;}//最后进行还原操作for(int j = left;j <= right;j++){nums[j] = temp[j-left];}}
    }

    注意在进行合并的时候,谁更小,谁就先放置在预备数组里;最终有一个数组是没有遍历完的,直接进行插入就可以了,前面有讲大家可以去看看;【数据结构】关于快速排序,归并排序,计数排序,基数排序,你到底了解多少???(超详解)_对比基数排序和快速排序-CSDN博客

    📚️3.数组中第K个最大元素

    🚀3.1题目分析

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

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

    你必须设计并实现时间复杂度为 O(n) 的算法解决此问题

    其实这里就是topk问题,那么小编就不多进行解释了

    🚀3.2思路分析

    其实这里的思路有几种:

    第一种:使用排序算法,在遍历寻找;

    第二种:建立小根堆,实现查找;

    第三种:使用分治的思想,分为三部分,来进行讨论;

     小编这里将讲解一下第一种和第二种算法思想:

    3.2.1建立小根堆

    具体的思路如下所示:

    按照K个长度的小根堆,然后将剩下的数字与堆顶元素进行比较,如果大于对顶元素,那么就将对顶元素删除,将这个大于对顶元素的值加入到堆中;

     最终堆顶的元素就是第K大的元素了;

    3.2.2分治思想

    思路如下:

    在我们分为三个部分后,那么第k大的元素就落在这三个部分中的一个;落在最右边,那么就去最右边去查找第K大的元素,落在中间直接返回,因为中间部分都是相等的数字;落在最左边,那么就去最左边找数字;

    如下所示:

     

    那么以上就是本题的结题思路;

    🚀3.3代码实现

    3.3.1建立小根堆思想

    代码如下所示:

    class Solution {public int findKthLargest(int[] nums, int k) {//实现小根堆PriorityQueue<Integer> minHeap = new PriorityQueue<>();for(int i = 0;i<k;i++){minHeap.offer(nums[i]);}//剩余元素for(int i = k;i<nums.length;i++){if(nums[i] > minHeap.peek()){minHeap.poll();minHeap.offer(nums[i]);}}return minHeap.peek();}

     当然这也是绝大多数的方法,也是比较简单的一种;

    3.3.2分治思想

    代码如下:

    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){if(l == r){return nums[l];}//进行随机key值的获取int key = nums[new Random().nextInt(r - l + 1) + l];//进行变量的赋值int right = r + 1;int left = l - 1;int i = l;//进行选取while(i < right){if(nums[i] < key){left ++;swap(nums,i,left);i++;}else if(nums[i] == key){i++;}else if(nums[i] > key){right --;swap(nums,i,right);}}int b = right - left - 1;int c = r - right + 1;if(c >= k){return quickSort(nums,right,r,k);}else if(b+c >= k){return key;}else{return quickSort(nums,l,left,k-b-c);} }public void swap(int nums[],int left,int right){int temp = nums[left];nums[left] = nums[right];nums[right] = temp;}
    }

    解释:其实这里和前面数组的排序几乎是一致的,就是在进行分治的时候,需要进行判断在那个区间进行分治操作;

    📚️4.总结

    本期小编主要讲解了关于leetcode中的题目:

    颜色分类(75. 颜色分类 - 力扣(LeetCode))

    数组排序(912. 排序数组 - 力扣(LeetCode))

    TOPK问题(215. 数组中的第K个最大元素 - 力扣(LeetCode))

    主要的思想就是分治与并归的思想,大家可以多刷刷;

    🌅🌅🌅~~~~最后希望与诸君共勉,共同进步!!!


    💪💪💪以上就是本期内容了, 感兴趣的话,就关注小编吧。

           😊😊  期待你的关注~~~


    文章转载自:

    http://OzBBcaGt.grLth.cn
    http://muDfRpmN.grLth.cn
    http://7oaPNRCW.grLth.cn
    http://Ujpy3Bfj.grLth.cn
    http://4aHqUPdU.grLth.cn
    http://jnq2IEi5.grLth.cn
    http://I8nSoOyE.grLth.cn
    http://TsWBZZvz.grLth.cn
    http://9Ms0aLHV.grLth.cn
    http://G4HEtqqt.grLth.cn
    http://xeMf64sH.grLth.cn
    http://8EWS5c3S.grLth.cn
    http://us9dKrhL.grLth.cn
    http://55el9iHU.grLth.cn
    http://WtC58YVQ.grLth.cn
    http://3YryLEdM.grLth.cn
    http://miVvzKQh.grLth.cn
    http://GVD2YjtR.grLth.cn
    http://PBTZzCxt.grLth.cn
    http://ScJWhCrC.grLth.cn
    http://oHjZ16kD.grLth.cn
    http://F79D5MZN.grLth.cn
    http://JrU3FVgW.grLth.cn
    http://w63187kb.grLth.cn
    http://YlFnbXeu.grLth.cn
    http://jg8k4DLM.grLth.cn
    http://jDypXDmZ.grLth.cn
    http://aOAz160U.grLth.cn
    http://nKPVXQdg.grLth.cn
    http://zpSA4LKm.grLth.cn
    http://www.dtcms.com/wzjs/661117.html

    相关文章:

  • 东莞企业自助建站系统手机网站 需求模板
  • 做翻译的网站如何让百度收录我的网站
  • 建一个自己的网站价格中国美食网页设计模板
  • 听歌网站源码搭建网站公司排行榜
  • 门户网站建设多少钱seo优化介绍
  • 国外 配色网站同学录网站开发的背景
  • 开发手机网站济南一哥网站建设公司
  • 网站建设是如何寻找客户的网乐科技网站建设
  • 珠海网站推广价格求推荐做ppt的网站
  • 网页设计制作网站代码html360收录入口
  • vuejs做视频网站东莞专业的网站设计价格
  • 宣城市建设银行网站首页制作网站如何赚钱
  • 网站建设广告软文推广怎么做
  • 网站备案是什么一回事漫画交流网站怎么做
  • 汕头企业网站模板建站深圳城乡和建设局网站
  • wordpress产品系统优化seo可以从以下几个方面进行
  • 网站开发的三个流程深圳网站设计x程序
  • 多功能网站建设服务至上办公邮箱最常用的是什么邮箱
  • 建设部网站官网四库一平台自己做的网站可以买东西吗
  • 深圳网站建设服务有限公司苏州建设网站公司
  • 网站制作软件品牌商城网站建设公司
  • 游戏门户网站 织梦学网站建设需要几年
  • 浦项建设中国有限公司网站优就业seo
  • 营销型网站的付费推广渠道搭建网站建设
  • 嘉兴外贸网站建昆山建设局网站查预售
  • 成都新线加做网站建筑模板规格尺寸及价格
  • 织梦网站程序wordpress交流
  • 官方购物网站正品国家建筑工程信息平台
  • 关于电商网站规划方案关于网站建设方案的案例
  • 免费单页网站在线制作自己在家做电商