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

韩国食品网站设计欣赏万象园网站建设与开发

韩国食品网站设计欣赏,万象园网站建设与开发,北京外贸营销网站建设费用,专业seo优化公司#xff01;#xff01;#xff01;排序仅针对于数组哦本次排序是按照升序来的哦代码后边有图解哦 介绍 快速排序英文名为Quick Sort 基本思路 快速排序采用的是分治思想#xff0c;即在一个无序的序列中选取一个任意的基准元素base#xff0c;利用base将待排序的序列分… 排序仅针对于数组哦本次排序是按照升序来的哦代码后边有图解哦 介绍 快速排序英文名为Quick Sort 基本思路 快速排序采用的是分治思想即在一个无序的序列中选取一个任意的基准元素base利用base将待排序的序列分成两部分前面部分元素均小于或等于基准元素后面部分均大于或等于基准元素然后采用递归的方法分别对前后两部分重复上述操作直到将无序序列排列成有序序列 代码 !----java----- import java.util.Arrays;public class QuickSort {public static void main(String[] args) {int[] arr {7,2,3,6,1,5,4}; // 待排序数组sort(arr,0, arr.length-1); // 方法调用left和right为带排序数组的起始位置和最终位置所以rightarr.length-1System.out.println(Arrays.toString(arr));}public static void sort(int[] arr,int left,int right){if(leftright){return;} // 判断带排序数组的长度严格的左边游标要不大于右边游标int base arr[left]; // 定义基准数int i left; // 定义左边的游标。这里不用left是因为left位置为基准数基准数不能变int j right; // 定义右边的游标。这里不用right是因为后续递归的时候需要一个参数while(i!j){ // 循环走起当i和j相遇时跟基准数交换。不相遇时i位置大于基准数j位置小于基准数时i位置和j位置的数交换/** 思考下为啥这里先是j在i前边 */while(arr[j]base ij){j--;} // 循环停止说明j指向的数值要比基准数小。降序为 while(arr[i]base ij){i;} // 循环停止说明i指向的数值要比基准数大。降序为 /** 【公布问题答案啦】* 因为j停下的时候代表当前数比基准数小i停下是当前数比基准数大。我们此次排序是升序相遇数要和基准数交换所以需要保证相遇数一定要小于基准数*/// 本次排序为升序即需要找到一个位置这个位置的左边都是比基准数小的右边都是比基准数大的int temp arr[i]; // i比基准数大j比基准数小交换。交换完成后i和j不等两个游标继续前走或后走arr[i] arr[j];arr[j] temp;}// i和j相遇,i也行j也行因为都指向一个嘛跟基准数交换。然后对基准数左右两遍递归arr[left] arr[i];arr[i] base;sort(arr,left,i-1);sort(arr,i1,right);} }!------------------------ 运行结果 [1, 2, 3, 4, 5, 6, 7]!----python----- def quickSort(arr, left, right):if left right:return arr;base arr[left];i, j left, right;while i ! j:while arr[j] base and i j:j - 1while arr[i] base and i j:i 1arr[j], arr[i] arr[i], arr[j];arr[i], arr[left] arr[left], arr[i];quickSort(arr,left,i-1);quickSort(arr,i1,right);return arrarr [7,2,3,6,1,5,4] print(quickSort(arr, 0, len(arr) - 1)) !------------------------ 运行结果 [1, 2, 3, 4, 5, 6, 7]代码思路及流程图直接上图不清楚可以对照代码看哦 复杂度 时间复杂度最好和平均情况下为O(n log n)最坏情况下为O(n^2)。空间复杂度最好情况下为O(log n)最坏情况下为O(n)额外空间为O(1)。 (复杂度先记住吧等后续研究彻底了会再写篇文章的)它是非稳定排序 扩展一下 Python的一个更简单的方法 # 该方法不适用java哦 def quickSort(arr):if len(arr)2:return arr;basearr[0];left [x for x in arr if xbase];middle [x for x in arr if xbase];right [x for x in arr if xbase];return quickSort(left)middlequickSort(right);arr[7,2,3,6,1,5,4]; print(quickSort(arr)) # [1, 2, 3, 4, 5, 6, 7]巩固一下 给定一个数组用上述方法进行排序流程是不是跟下图一样呢 int[] arr {3,7,1,6,2,5,4} 文章推荐 实在是不会做动画如果还看不懂可以移步这里 十大经典排序算法 【漫画】不要再问我快速排序了有错误请指正谢谢各位~
http://www.zqtcl.cn/news/691810/

相关文章:

  • 网站添加锚点网站备案名称更换
  • 手机商城网站如何企业网站建设及运营现状分析
  • 网站建设注意的问题网站模板 知乎
  • 自主设计和创建网站网站建设价格便宜
  • 高手做网站财经资讯网站该怎么做推广
  • 加强农业网站建设青岛全网营销推广
  • 做淘客网站怎么样济南软件公司排名
  • 企业网站优化兴田德润怎么样网站建设建设公司资质要求
  • 如何把网站做跳转浏览器链接地址wordpress 离线更新
  • 乌海学校网站建设wordpress默认主题下载
  • 海兴县做网站如何选网站建设公司
  • asp网站设为首页代码孝仙洪高速公路建设指挥部网站
  • 浦东新区网站开发人才网站建设策划书
  • 网站做flash好不好免费微信公众号素材网
  • 开发网站嵌入广告汕头电商网站建设
  • 电脑做科目一网站购物网站怎么创建
  • c2c网站建设公司wordpress被公众号干掉
  • wordpress托管建站网站页面布局和样式设计
  • 建站平台江苏省建设监理协会网站
  • 安徽网站开发培训价格百度seo排名公司
  • 青海网站建设费用oa系统和erp系统区别
  • 个人做网站的注意事项网站开发工程师6
  • 镇江百度网站建设北京网站开发价格
  • 大岭山镇仿做网站推广计划表格
  • 网站备案地址不是我的地址怎么办建设银行网站查询业务收费吗
  • 电商网站设计内容网站编辑及seo招聘
  • 用什么网站开发浙江省住房和建设厅网站
  • 站长工具seo优化建议微信小程序线上商城怎么申请
  • 建筑网站开发设计做网站的公司msgg
  • 设计师个人网站模板网站的尾页要怎么做