java实现常用排序

  排序(sorting )的功能是将一个数据元素的任意序列,重新排列成一个按关键字有序的序列。根据排序时待排序的数据元素数量的不同,使得排序过程中涉及的存储器不同,可以将排序方法分为两类。一类是整个排序过程在内存储器中进行,称为内部排序;另一类是由于待排序元素数量太大,以至于内存储器无法容纳全部数据,排序需要借助外部存储设备才能完成,这类排序称为外部排序。


  1.插入排序(直接插入排序、希尔排序)

  1.1 直接插入排序
  直接插入排序是一种最简单的插入排序方法,它的基本思想是:仅有一个元素的序列总是有序的,因此,对 n 个记录的序列,可从第二个元素开始直到第 n 个元素,逐个向有序序列中执行插入操作,从而得到n 个元素按关键字有序的序列。
  一般来说,在含有j-1 个元素的有序序列中插入一个元素的方法是:从第j-1 个元素开始依次向前搜索应当插入的位置,并且在搜索插入位置的同时可以后移元素,这样当找到适当的插入位置时即可直接插入元素。
    以关键字序列{ 26 , 53 , 48 , 11 , 13 ,  48 , 32 , 15}为例
    

     代码1:
    
public void StraightInsertSort(double[] sorted){
		int sortlen =sorted.length;
		for(int i=2;i<sortlen;i++){
			if(sorted[i]<sorted[i-1]){
				sorted[0]=sorted[i];
				sorted[i]=sorted[i-1];
				int insertpos =0;  //插入位置
				for(int j=i-2;j>=0;j--){
					if(sorted[j]>sorted[0]){
						sorted[j+1]=sorted[j];
					}else{
						insertpos = j+1;
						break;
					}
					
				}
				sorted[insertpos]=sorted[0];
			}
		}
		
	}
代码2:
   
	public void insertSort(Object[] r, int low, int high){ 
		  for (int i=low+1; i<=high; i++) 
		   if (r[i]<r[i-1]){ //小于时,需将 r[i]插入有序表   
		    Object temp = r[i];    
		    r[i] = r[i-1]; 
		    int j=i-2; 
		    for (; j>=low&&temp<r[j]; j--) 
		     r[j+1] = r[j];   //记录后移 
		    r[j+1] = temp;    //插入到正确位置 
             } 
	 } 




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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值