java常见的排序算法

冒泡排序从头开始扫描待排序的元素,在扫描过程中依次对相邻元素进行比较,将关键字值大的元素后移。每经过一趟排序后,关键字值最大的元素将移到末尾(需要比较元素的个数减一),此时记下该元素的位置,下一趟排序只需要比较到此位置为止,直到所有元素都已有序排列。时间复杂度为O(n2)



快速排序:选择一个基准元素,通常选择第一个元素或者最后一个元素,通过一趟扫描,将待排序列分成两部分,一部分比基准元素小,一部分大于等于基准元素,此时基准元素在其排好序后的正确位置,然后再用同样的方法递归地排序划分的两部分。

 package studuy.ecs;
// 快速排序是对冒泡排序的一种改进。它的基本思想是:通过一躺排序将要排序的数据分割成独立的两部分,
//其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按次方法对这两部分数据分别进行快速排序,
//整个排序过程可以递归进行,以此达到整个数据变成有序序列。最坏情况的时间复杂度为O(n2),最好情况时间复杂度为O(n*log2n)

public class Kspx {
public static void quicksort(int a[],int left,int right){
  if(left>=right){  
return;    
  }
  int i = left;
  int j = right;
  int temp = a[left];  //选取第一个数(这里也可选其他的数)作为比较的基石
  
  while(i<j)
  {
   while(j>i&&a[j]>=temp){  
    j--;
    }    
    if(j>i){
         a[i++]=a[j];
    }     
    while(j>i&&a[i]<=temp){
     i++;
    }
    if(j>i){
     a[j--]=a[i];
    } 
  }
  a[i]=temp;
  quicksort(a,left,i-1);
  quicksort(a,i+1,right);
}


插入排序:插入排序就是把当前待排序的元素插入到一个已经排好序的列表里面。插入排序的最坏运行时间是O(n2), 所以并不是最优的排序算法。特点是简单,不需要额外的存储空间,在元素少的时候工作得好。



选择排序: 每一次从待排序的数据元素中选出最小(或最大)的一个元素,顺序放在已排好序的数列的最后,直到全部待排序的数据元素排完。与冒泡排序相比,两者的比较次数是相同的,但是选择排序交换的次数少于冒泡排序,提升了排序的效率。时间复杂度为O(n2)


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值