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

模板网站的建设天眼查全国企业查询

模板网站的建设,天眼查全国企业查询,外贸网站建站多少钱,网页升级访问更新狼博主主页: 码农派大星. 数据结构专栏:Java数据结构 数据库专栏:MySQL数据库 关注博主带你了解更多数据结构知识 1.冒泡排序 冒泡排序 private static void swap(int[] arrary,int i,int j){int tmp arrary[i];arrary[i] arrary[j];arrary[j] tmp;public static void bubbl…


 博主主页: 码农派大星.

    数据结构专栏:Java数据结构

 数据库专栏:MySQL数据库

关注博主带你了解更多数据结构知识


1.冒泡排序

冒泡排序

private static void swap(int[] arrary,int i,int j){int tmp = arrary[i];arrary[i] = arrary[j];arrary[j] = tmp;public static void  bubbleSort(int[] arrary){for (int i = 0; i <arrary.length-1 ; i++) {for (int j = 0; j < arrary.length-1-i; j++) {if(arrary[j]> arrary[j+1]){swap(arrary,j,j+1);}}}return arrary;}

冒泡排序总结

1. 冒泡排序是一种非常容易理解的排序

2. 时间复杂度:O(N^2)

3. 空间复杂度:O(1)

4. 稳定性:稳定 

2.快速排序

快速排序是Hoare于1962年提出的一种二叉树结构的交换排序方法,其基本思想为:任取待排序元素序列中的某元 素作为基准值,按照该排序码将待排序集合分割成两子序列,左子序列中所有元素均小于基准值,右子序列中所有 元素均大于基准值,然后最左右子序列重复该过程,直到所有元素都排列在相应位置上为止。

1.Hoare版

public static void  quickSort(int[] arrary){quick(arrary,0,arrary.length-1);return arrary;}private static void swap(int[] arrary,int i,int j){int tmp = arrary[i];arrary[i] = arrary[j];arrary[j] = tmp;private static void quick(int [] arrary,int start,int end){if (start >= end) {return;}int par = partition(arrary,start,end);quick(arrary,start,par-1);quick(arrary,par+1,end);}private static int partition(int [] arrary,int left,int right){int i = left;int tmp = arrary[left];while (left < right){//right-- : 先走左边会导致最后相遇的地方比基准大的数据,// 交换完后,会把大于基准的值换到前面while (left < right && arrary[right] >= tmp){right--;}while (left < right && arrary[left] <= tmp){left++;}swap(arrary,left,right);}//此时相遇left=right;swap(arrary,left,i);return right;}

2.挖坑法 

public static void  quickSort(int[] arrary){quick(arrary,0,arrary.length-1);return arrary;}
private static void quick(int [] arrary,int start,int end){if (start >= end) {return;}int par = partitionWaken(arrary,start,end);quick(arrary,start,par-1);quick(arrary,par+1,end);}
private static int partitionWaken(int [] arrary,int left,int right){int tmp = arrary[left];while (left<right){while (left < right && arrary[right] >= tmp){right--;}arrary[left] = arrary [right];while (left<right && arrary[left] <= tmp){left++;}arrary[right] = arrary[left];}arrary[left] = tmp;return left;}

3.快速排序优化

1. 三数取中法选key

public static void  quickSort(int[] arrary){quick(arrary,0,arrary.length-1);
return arrary;}private static void quick(int [] arrary,int start,int end){if (start >= end) {return;}int index = midThreeNum(arrary,start,end);swap(arrary,index,start);int par = partitionWaken(arrary,start,end);quick(arrary,start,par-1);quick(arrary,par+1,end);}private static int partitionWaken(int [] arrary,int left,int right){int tmp = arrary[left];while (left<right){while (left < right && arrary[right] >= tmp){right--;}arrary[left] = arrary [right];while (left<right && arrary[left] <= tmp){left++;}arrary[right] = arrary[left];}arrary[left] = tmp;return left;}private static int midThreeNum(int [] arrary,int left,int right){int mid = (left+right)/2;if (arrary[left] < arrary[right]){if (arrary[mid] < arrary[left]) {return left;}else if (arrary[mid] > arrary[right]){return right;}else {return mid;}}else{if (arrary[mid] < arrary[right]){return right;}else if(arrary[mid] > arrary[left]){return left;}else {return mid;}}}

2. 递归到小的子区间时,可以考虑使用插入排序

我们在数组中数据小于等于10时改为插入排序,提高了排序的效率.

 public static void  quickSort(int[] arrary){quick(arrary,0,arrary.length-1);
return arrary;}private static void quick(int [] arrary,int start,int end){if (start >= end) {return;}if (end - start + 1 <= 10) {inserSortRange(arrary,start,end);return;}int index = midThreeNum(arrary,start,end);swap(arrary,index,start);int par = partitionWaken(arrary,start,end);quick(arrary,start,par-1);quick(arrary,par+1,end);}public static  void inserSortRange(int [] array,int left,int right){for(int i = left+1; i< right;i++){int tmp = array[i];int j = i-1;for (; j >=0 ; j--) {if (array[j] > tmp) {array[j+1] = array[j];}else {//array[j+1]= tmp;break;}}array[j+1]= tmp;}}private static int partitionWaken(int [] arrary,int left,int right){int tmp = arrary[left];while (left<right){while (left < right && arrary[right] >= tmp){right--;}arrary[left] = arrary [right];while (left<right && arrary[left] <= tmp){left++;}arrary[right] = arrary[left];}arrary[left] = tmp;return left;}private static int midThreeNum(int [] arrary,int left,int right){int mid = (left+right)/2;if (arrary[left] < arrary[right]){if (arrary[mid] < arrary[left]) {return left;}else if (arrary[mid] > arrary[right]){return right;}else {return mid;}}else{if (arrary[mid] < arrary[right]){return right;}else if(arrary[mid] > arrary[left]){return left;}else {return mid;}}}

4.非递归的快速排序 

//非递归快速排序public static void quickNot(int[] array){Stack<Integer> stack = new Stack<>();int left = 0;int right = array.length - 1;int par = partition(array,left,right);if (par > left+1){stack.push(left);stack.push(par-1);}if (par < right-1){stack.push(par+1);stack.push(right);}while (!stack.isEmpty()){right = stack.pop();left = stack.pop();par = partitionWaken(array,left,right);if(par > left+1){stack.push(left);stack.push(par-1);}if (par < right -1){stack.push(par+1);stack.push(right);}}return array;}
private static int partition(int [] arrary,int left,int right){int i = left;int tmp = arrary[left];while (left < right){//right-- : 先走左边会导致最后相遇的地方比基准大的数据,// 交换完后,会把大于基准的值换到前面while (left < right && arrary[right] >= tmp){right--;}while (left < right && arrary[left] <= tmp){left++;}swap(arrary,left,right);}//此时相遇left=right;swap(arrary,left,i);return right;}

未优化的快速排序,再遇到数据过多时,程序会崩. 

1. 快速排序整体的综合性能和使用场景都是比较好的,所以才敢叫快速排序

2. 时间复杂度:O(N*logN)

快速排序和堆排序时间复杂度一样,但是快速排序要比堆排序快

3. 空间复杂度:O(logN)

4. 稳定性:不稳定


文章转载自:

http://fTcQYbfD.qdxwf.cn
http://8LqkyvdO.qdxwf.cn
http://DK3ysKEL.qdxwf.cn
http://E8yqzb3t.qdxwf.cn
http://4ufikVix.qdxwf.cn
http://yHZKJu2m.qdxwf.cn
http://WUOXJqJs.qdxwf.cn
http://IpfcmuEJ.qdxwf.cn
http://29L3HtUI.qdxwf.cn
http://nfVWPJKl.qdxwf.cn
http://PObpJmWY.qdxwf.cn
http://5Ww1sYGt.qdxwf.cn
http://TY25GSwB.qdxwf.cn
http://ELUC6en1.qdxwf.cn
http://mPmlDDNn.qdxwf.cn
http://8U8CsrSy.qdxwf.cn
http://wvQZlAQB.qdxwf.cn
http://nOloVHi4.qdxwf.cn
http://s38l7pA7.qdxwf.cn
http://g2vNlYdp.qdxwf.cn
http://fFc23367.qdxwf.cn
http://v6eXD8wT.qdxwf.cn
http://M4fKoKAn.qdxwf.cn
http://qlCOuWGh.qdxwf.cn
http://0vMIBeLk.qdxwf.cn
http://rs5mJiEz.qdxwf.cn
http://E6HC2doM.qdxwf.cn
http://mF2wZG2R.qdxwf.cn
http://rzLCrcdO.qdxwf.cn
http://ZX3mhWM7.qdxwf.cn
http://www.dtcms.com/wzjs/700181.html

相关文章:

  • 东营网站seo外包WordPress显示403
  • 个人网站 做导航长沙网站建设长沙建设银行
  • 手机网站做指向php网站建设制作服务
  • 网站首页面设计代码网站的制
  • 邯郸企业建站行政法规
  • 网站备案是备案域名还是空间深圳头条新闻
  • 什么网站可以做外贸怎么做一个公司的网站
  • 公司做网站的费用怎么入账企业邮箱登录入口126
  • 如何做公司网站制作西安网站设设
  • 国内做服装的网站有哪些国内永久免费的crm
  • 邯郸老区建设网站如何分析竞争对手的网站
  • 高端品牌网站设计企业网站建设项目建设全过程有哪些阶段
  • 网站做优化和推广哪个好免费域名网站黄
  • 小米官网网站建设公司建一个网站多少费用
  • 网站建设设计师我的网站突然打不开了
  • 青岛商媒做网站怎么样网站做反向代理对百度收录有影响吗
  • 网站服务器无法访问电子商务网站开发教程课后习题
  • 建设网站网页打不开WordPress抓取豆瓣
  • 广州网站的建设软件开发入门
  • 无忧网站建设报价什么是黄页
  • 网站建设维护合同合肥网站代运营公司有哪些
  • 用seo对网站做分析山东网站制作
  • 郑州网站开发yipinpai山东网站建设SEO优化制作设计公司
  • 有什么网站可以做设计兼职在线制作图片加闪光字
  • dedecms网站管理系统国外vps私人
  • 一个做特卖的网站做婚礼策划的网站
  • 广州天河建站公司广西建设执业资格注册中心官网
  • 备案域名购买完过户简单吗郑州网站seo公司
  • 手机建立网站多少钱北京网站优化排名
  • 网站建设的书 豆瓣中国能建电子商务平台