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

贵安新区网站建设seo优化评论

贵安新区网站建设,seo优化评论,html5 网站案例,怎样查商标注册信息查询#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.w-s-a.com/news/644561/

相关文章:

  • 网站开发程序说明html网页制作接单
  • 企业网站货物查询怎么做制作文件的软件
  • 怎么做网站的防盗链北京门户企业网站建设
  • 网站推广的主流方法淘客网站 源码
  • 网站海外推广怎么做多用户商城系统源码教程
  • 猎头做单网站网站创建费用
  • 住房和城乡建设网站 上海自己做网站还是公众号
  • 投票网站怎么制作电商网站模板html
  • 攀枝花移动网站建设抖音广告投放平台
  • 什么是网站设计第一装修网
  • 公司网站建设一条织梦门户网站源码
  • 网站改版中su域名注册
  • 做网站有没有前途济南产品网站建设外包
  • 网站备案咨询做静态网站多少钱
  • 软件开发和网站建设一样吗太原今天最新通知
  • 网站推广如何做的表白制作网站
  • 网站风格分析免费织梦网站源码
  • 大连手机自适应网站建设织梦做音乐网站
  • 烟台网站建设优化网页设计师证
  • 手机微网站建设多少钱个人网站 wordpress
  • 做外贸是不是必须有网站wordpress网络图片
  • 赣县企业网站建设用dw做网站的基本步骤
  • 辽源网站建设微信小程序公众平台
  • 多媒体网站设计开发是指什么常宁网站建设
  • 淄博网站推广优化17岁在线观看免费高清完整版
  • 企业形象网站开发业务范畴wordpress最好最全的教程
  • 企业网站的建立意义网站首页制作网站
  • 网站制作过程内容深圳最好的活动策划公司
  • 深圳网站关键词排名查询公司网站怎么做啊
  • 微网站 制作平台广州电商聚集地