博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
排序(自己写的)
阅读量:5119 次
发布时间:2019-06-13

本文共 1463 字,大约阅读时间需要 4 分钟。

1.快速排序

package 测试;public class Quick {public static void quickSort(int arr[],int _left,int _right){int left = _left;int right = _right;int temp = 0;if(left <= right){ //待排序的元素至少有两个的情况temp = arr[left]; //待排序的第一个元素作为基准元素while(left != right){ //从左右两边交替扫描,直到left = rightwhile(right > left && arr[right] >= temp) right --; //从右往左扫描,找到第一个比基准元素小的元素arr[left] = arr[right]; //找到这种元素arr[right]后与arr[left]交换while(left < right && arr[left] <= temp)left ++; //从左往右扫描,找到第一个比基准元素大的元素arr[right] = arr[left]; //找到这种元素arr[left]后,与arr[right]交换}arr[right] = temp; //基准元素归位quickSort(arr,_left,left-1); //对基准元素左边的元素进行递归排序quickSort(arr, right+1,_right); //对基准元素右边的进行递归排序} }public static void main(String[] args) {int array[] = {10,5,3,1,7,2,8};System.out.println("排序之前:");for(int element : array){System.out.print(element+" ");}quickSort(array,0,array.length-1);System.out.println("\n排序之后:");for(int element : array){System.out.print(element+" ");}}}

  

 

算法分析:1.当分区选取的基准元素为待排序元素中的最大或最小值时,为最坏的情况,时间复杂度和直接插入排序的一样,移动次数达到最大值

                  Cmax = 1+2+...+(n-1) = n*(n-1)/2 = O(n2) 此时最好时间复杂为O(n2

              2.当分区选取的基准元素为待排序元素中的"中值",为最好的情况,时间复杂度为O(nlog2n)。

              3.快速排序的空间复杂度为O(log2n). 

              4.当待排序元素类似[6,1,3,7,3]且基准元素为6时,经过分区,形成[1,3,3,6,7],两个3的相对位置发生了改变,所是快速排序是一种不稳定排序。

 

2.选择排序

for(int i=0;i
a[j]){ min=j; } } if(i!=min){ int t=a[i]; a[i]=a[min]; a[min]=t; } }

 

3.插入排序

for(int i=1;i
0) { a[n-1]=a[n]; n--; } a[n]=a[i]; }

  

转载于:https://www.cnblogs.com/zhaosong-0102/p/7655224.html

你可能感兴趣的文章
js window.open 参数设置
查看>>
032. asp.netWeb用户控件之一初识用户控件并为其自定义属性
查看>>
Ubuntu下安装MySQL及简单操作
查看>>
前端监控
查看>>
clipboard.js使用方法
查看>>
移动开发平台-应用之星app制作教程
查看>>
leetcode 459. 重复的子字符串(Repeated Substring Pattern)
查看>>
伪类与超链接
查看>>
centos 7 redis-4.0.11 主从
查看>>
博弈论 从懵逼到入门 详解
查看>>
永远的动漫,梦想在,就有远方
查看>>
springboot No Identifier specified for entity的解决办法
查看>>
慵懒中长大的人,只会挨生活留下的耳光
查看>>
"远程桌面连接--“发生身份验证错误。要求的函数不受支持
查看>>
【BZOJ1565】 植物大战僵尸
查看>>
VALSE2019总结(4)-主题报告
查看>>
浅谈 unix, linux, ios, android 区别和联系
查看>>
51nod 1428 活动安排问题 (贪心+优先队列)
查看>>
中国烧鹅系列:利用烧鹅自动执行SD卡上的自定义程序(含视频)
查看>>
Solaris11修改主机名
查看>>